Vue基础-自定义指令的使用

Vue的内置指令已经有很多了,比如 v-if、v-on 、v-show、v-for等等。在这些指令中,已经大部分可以满足大部分的业务需求了。不过如果要开发一些比较特殊的功能,就需要我们自己自定义一些指令来完成。

举例:

如何实现打开页面时,input会自动获取焦点?

这里写图片描述

(https://img-blog.csdn.net/20180107164046991?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbGFuZGVyX3hpb25n/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
<div id="app">
   <input type="text" v-focus>
</div>
<script>
  Vue.directive('focus', {
    inserted: function (el) {
      el.foucs();
    }
  })
  var app = new Vue({
    el: '#app'
  })
</script>

上面是一个简单的自定义指令的例子,下面我们来分析一下自定义指令的注册方法和参数。

自定义指令的注册方法有:
  • 全局注册
Vue.directive('test', {
  //指令选项
})
  • 局部注册
var app = new Vue({
  el: '#app',
  directieve: {
    test: {
      //指令选项
    }
  }
})
自定义指令的选项

自定义的选项是由几个钩子函数组成的,下面分别介绍一下这几个钩子的含义:

  • bind: 只调用一次,在绑定到元素时调用,通常是在绑定时执行一次初始化的动作。
  • inserted: 被绑定元素插入父节点时调用,如上面例子中使用的,元素在初始化时自动获取焦点。
  • update: 被绑定元素所在的模板更新是调用,不论绑定值是否有变化。
  • componentUpdated:被绑定元素所在的模板完成一次更新周期时调用。
  • unbing: 只调用一次,指令与元素解绑时调用。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值