一、什么是自定义指令
vue 官网注释 https://cn.vuejs.org/v2/guide/custom-directive.html
二、详解及示例
1、自定义指令
Vue.directive('my-directive', {
bind: function () {},
inserted: function (newValue, oldValue) { },
update: function (newValue, oldValue) {},
componentUpdated: function(newValue, oldValue) {},
unbind: function () {}
})
2、钩子函数
bind:只调用一次,指令第一次绑定到元素时使用,用这个钩子函数,可以做一些初始化的动作。
inserted:被绑定元素插入父节点时调用(父节点存在即可调用,不必存在于 document 中)。
update:所在组件的 VNode 更新时调用,但是可能发生在其孩子的 VNode 更新之前。指令的值可能发生了改变也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新。
componentUpdated: 所在组件的 VNode 及其孩子的 VNode 全部更新时调用。
unbind: 只调用一次, 指令与元素解绑时调用。
3、 钩子函数参数
el:指令所绑定的元素,可以用来直接操作 DOM 。
binding:一个对象,包含以下属性:
name:指令名,不包括 v- 前缀。
value:指令的绑定值, eg: v-my-directive=”1 + 1”, value 的值是 2。
oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
expression:绑定值的字符串形式。 eg:v-my-directive=”1 + 1” , expression 的值是 “1 + 1”。
arg:传给指令的参数。例如 v-my-directive:foo, arg 的值是 “foo”。
modifiers:一个包含修饰符的对象。 eg: v-my-directive.foo.bar, 修饰符对象 modifiers 的值是 { foo: true, bar: true }。
vnode:Vue 编译生成的虚拟节点
oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。