最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

内部自定义指令和全局自定义指令的实现

来源:动视网 责编:小采 时间:2020-11-27 20:16:40
文档

内部自定义指令和全局自定义指令的实现

内部自定义指令和全局自定义指令的实现:在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东directive这个单词是我们写自定义指令的关键字哦之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表
推荐度:
导读内部自定义指令和全局自定义指令的实现:在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东directive这个单词是我们写自定义指令的关键字哦之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表
 在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东

directive

这个单词是我们写自定义指令的关键字哦

之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表现状态

  • bind: 只调用一次,指令第一次绑定到元素时调用,用这个钩子函数可以定义一个在绑定时执行一次的初始化动作。

  • inserted: 被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。

  • update: 被绑定元素所在的模板更新时调用,而不论绑定值是否变化。通过比较更新前后的绑定值,可以忽略不必要的模板更新(详细的钩子函数参数见下)。

  • componentUpdated: 被绑定元素所在模板完成一次更新周期时调用。

  • unbind: 只调用一次, 指令与元素解绑时调用。

  • 下面我们开始上代码,让我们更好的理解自定义指令怎么做

    <!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>Document</title><script src="https://unpkg.com/vue/dist/vue.js?1.1.11"></script></head><body><div id="app"><div class="ab" v-css="{'color':'red','font-size':'30px'}">hello</div><input type="text" v-focus></div>
     </body></html>

    在html中,我们看到了两个指令v-css和v-focus

    我们自定义指令时候,一定前面要带上v-

    Vue.directive("css",{//钩子函数 ,el就是当前元素 inserted(el,binding){//el绑定的元素本身//binding就是css指令里面的的对象元素let styleobj=binding.value,arr=[];for(let key in styleobj){
     arr.push(key+":"+styleobj[key])
     }
     arr=arr.join(";");
     el.style.cssText=arr;
     },
     bind(el,binding) {//指令绑定在元素上时候执行,只执行一次 }
    });new Vue({
       el:'#app',
     data:{
     show:true},
     directives:{
     focus:{
     inserted(el,binding){//el绑定的元素本身//binding就是css指令里面的的对象元素 el.focus();
     }
     }
     }
     });

    在js里面我们可以看到

    Vue.directive("css",{})

    我们在 new Vue外部定义了这样一段代码,这就是我们全局自定义指令的模板方式

    css是自定义指令的名字

    {}里面我们写上钩子函数就可以

    我们所有的钩子函数里面,基本都会有2个参数el,binding

  • el: 指令所绑定的元素,可以用来直接操作 DOM 。

  • binding 绑定元素本身的一个对象

  • 从上面我们可以看到,binding里面保留绑定指令的name和value,这些很重要

    局部自定义指令

    directives:{
    name:{

    }
    }

    区别在于,我们写在new Vue里面,里面api操作和上面的全局自定义指令一样

    下面我们开始看代码运行结果

    我们可以看到样式引用上去了

    文本框也获取了焦点

    文档

    内部自定义指令和全局自定义指令的实现

    内部自定义指令和全局自定义指令的实现:在Vue中,我们平时数据驱动视图时候,内部自带的指令有时候解决不了一些需求,这时候,Vue给我们一个很好用的东东directive这个单词是我们写自定义指令的关键字哦之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表
    推荐度:
    标签: 内部 全局 指令的
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top