全局注册Vue.directive

1.src目录下新建directives文件

export default {
install: function(Vue, option) {
// 1:el指绑定的dom元素
// 2:binding一个对象,包含指令的很多信息, 使用时可以绑定的值
// 3:vnodeVUE编译生成的虚拟节点
Vue.directive('focus', {
bind: function (el, binding, vnode) {
el.style['color'] = binding.value
}, // 只调用一次,指令第一次绑定到元素时候调用,用这个钩子可以定义一个绑定时执行一次的初始化动作。
inserted: function () {}, // 被绑定的元素插入父节点的时候调用(父节点存在即可调用,不必存在document中)
update: function () {}, // 被绑定与元素所在模板更新时调用,而且无论绑定值是否有变化,通过比较更新前后的绑定值,忽略不必要的模板更新
componentUpdated: function () {}, // 被绑定的元素所在模板完成一次更新更新周期的时候调用
unbind: function () {} // 只调用一次,指令元素解绑的时候调用
})
}
}

2.min.js中全局引入

import directive from './directive/directive' // 引入directive

Vue.use(directive) // 引入directive

3.组件中使用自定义指令

<template>
  <el-row :gutter="6" class="box">
      <!-- directive第一个参数就是绑定的指令名称 -->
      <div v-change-color="color">点我</div>
  </el-row>
</template>

<script>
export default {
  name: 'BigScreen',
  data() {
    return {
        color: 'red'
    }
  }
}
</script>
posted @ 2020-01-10 10:36  格里兹曼  阅读(837)  评论(0编辑  收藏  举报