【Vue】自定义指令

简介: 【Vue】自定义指令

hello,我是小索奇,精心制作的Vue系列持续发放,涵盖大量的经验和示例,如果对您有用,可以点赞收藏哈~

自定义指令

自定义指令就是自己定义的指令,是对 DOM 元素进行底层操作封装 ,程序化地控制 DOM,拓展额外的功能


全局定义

Vue.directive(指令名字, definition)


  • 指令名:不包括v-前缀,使用时候包括v-,v-指令名
  • definition: 对象,包含指令逻辑
// definition 就代表下面的函数,
Vue.directive('focus', function(el, binding) {
  // el 是绑定的 DOM 元素
})

局部定义

new Vue({
  directives: {
    'focus': {

    }
  }
})

directives: {
// 直接写成函数形式,部分细节问题会处理不了
  focus(el, binding) {

  }  
}


指令definition对象可以访问以下参数:


el: 指令绑定的DOM元素,可以直接操作

binding: 对象,包含指令信息

name: 指令名

value: 指令绑定的值

expression: 绑定表达式字符串

arg: 参数

modifiers: 修饰符

vnode: Vue编译的虚拟节点

oldVnode: 之前的虚拟节点

示例1

创建一个自定义指令

<p v-color>鼠标悬停我,我会变色!</p>


在这里,v-color 就是我们的自定义指令它的名字是由我们来决定的,这个名字后面我们会用到

创建自定义指令的逻辑

<script>
  directives: {
  // 写成对象形式,可以定义更多函数
    color: {
      bind(el,binding) {
        console.log(el)
    console.log(binding)
        el.addEventListener('mouseover', () => {
          el.style.color = 'red'; // 鼠标悬停时变红色
        });

        el.addEventListener('mouseout', () => {
          el.style.color = ''; // 鼠标移出恢复原色
        });
      }
    }
}
</script>

在 bind 钩子函数和其他一些钩子函数中,el 是HTMLElement真实DOM元素一个必传参数,表示绑定了指令的 DOM 元素我们可以通过操作 el 来修改元素的样式、属性等


binding 是一个包含了指令相关信息的对象


我们告诉Vue当使用 v-color 指令时,应该执行的逻辑是:当鼠标悬停在元素上时,把文字变成红色;当鼠标移出时,恢复原来的颜色


我们已经在模板中使用了自定义指令 v--color,Vue会自动找到这个指令,并且执行我们之前定义的逻辑


el就代表绑定的元素,这里绑定的是h1



value是什么?

当我给v-color制定值的时候,它就出现了,所以binding.value就是我们绑定的value

示例2

<button @click="n++">点我n+1</button>
// 如果指令名有多个字母组成,要求使用烤肉串方式,如:v-focus-bind,相应的key应该加上引号
<input type="text" v-fbind:value="n">

directives: {
        //函数是在 1.指令第一次绑定到元素时触发2.指令所在的模板被重新解析时触发
        // fbind(element,binding){
        // },
        // 写成对象形式,对象中可以定义更多函数,也可以写更多细节
        fbind:{
          //指令与元素成功绑定时,一上来立即会被调用,和函数形式调用时机一样fbind(){}
          bind(el,binding){
            el.value = binding.value
          },
          //指令所在元素被插入页面时
          inserted(el,binding){
            el.focus()
          },
          //指令所在的模板被重新解析时
          update(el,binding){
            el.value = binding.value
          }
        }
      }

全局形式

 Vue.directive('fbind',{
      bind(element,binding){
        element.value = binding.value
      },
      inserted(element,binding){
        element.focus()
      },
      update(element,binding){
        element.value = binding.value
      }

定义成函数形式,相当于对象中的bind和update,没有inserted的简写,如需要更多细节操作可以定义对象形式


拓展钩子函数

Vue 自定义指令的常见钩子函数包括:


  • bind: 指令第一次绑定到元素时触发
  • inserted: 元素被插入到父元素时触发
  • update: 指令所在的模板被重新解析时触发
  • componentUpdated: 组件更新完成时触发
  • unbind: 指令与元素解绑时触发


这些钩子函数名称是 Vue 所识别的,如果我们在自定义指令中使用这些名称,Vue 就会在相应的时机调用我们的指令逻辑



相关文章
|
7天前
|
JavaScript 前端开发
如何在 Vue 项目中配置 Tree Shaking?
通过以上针对 Webpack 或 Rollup 的配置方法,就可以在 Vue 项目中有效地启用 Tree Shaking,从而优化项目的打包体积,提高项目的性能和加载速度。在实际配置过程中,需要根据项目的具体情况和需求,对配置进行适当的调整和优化。
|
7天前
|
存储 缓存 JavaScript
在 Vue 中使用 computed 和 watch 时,性能问题探讨
本文探讨了在 Vue.js 中使用 computed 计算属性和 watch 监听器时可能遇到的性能问题,并提供了优化建议,帮助开发者提高应用性能。
|
7天前
|
存储 缓存 JavaScript
如何在大型 Vue 应用中有效地管理计算属性和侦听器
在大型 Vue 应用中,合理管理计算属性和侦听器是优化性能和维护性的关键。本文介绍了如何通过模块化、状态管理和避免冗余计算等方法,有效提升应用的响应性和可维护性。
|
7天前
|
存储 缓存 JavaScript
Vue 中 computed 和 watch 的差异
Vue 中的 `computed` 和 `watch` 都用于处理数据变化,但使用场景不同。`computed` 用于计算属性,依赖于其他数据自动更新;`watch` 用于监听数据变化,执行异步或复杂操作。
|
6天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
|
8天前
|
存储 JavaScript 开发者
Vue 组件间通信的最佳实践
本文总结了 Vue.js 中组件间通信的多种方法,包括 props、事件、Vuex 状态管理等,帮助开发者选择最适合项目需求的通信方式,提高开发效率和代码可维护性。
|
6天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
|
8天前
|
存储 JavaScript
Vue 组件间如何通信
Vue组件间通信是指在Vue应用中,不同组件之间传递数据和事件的方法。常用的方式有:props、自定义事件、$emit、$attrs、$refs、provide/inject、Vuex等。掌握这些方法可以实现父子组件、兄弟组件及跨级组件间的高效通信。
|
13天前
|
JavaScript
Vue基础知识总结 4:vue组件化开发
Vue基础知识总结 4:vue组件化开发
|
13天前
|
存储 JavaScript
Vue 状态管理工具vuex
Vue 状态管理工具vuex