Vue中directive的钩子函数(bind,inserted等)用法及使用说明

 更新时间:2025年07月26日 11:37:23   作者:前端布洛芬  
Vue指令钩子函数(bind、inserted等)用于在不同阶段操作元素,bind绑定时初始化,inserted插入DOM后执行,update值变化时触发,componentUpdated全部更新后调用,unbind解绑时清理,根据需求选择对应钩子实现功能增强

Vue中directive的钩子函数(bind,inserted等)用法

在 Vue 里,指令(directive)是个超实用的东西,它能让你在不改动组件逻辑的情况下,给 HTML 元素添加一些特殊的行为。Vue 指令有好几个钩子函数,下面我就挨个给你讲讲这些钩子函数的作用和使用场景,还会附上带注释的代码示例。

1.bind钩子函数

  • 作用bind 钩子函数会在指令第一次绑定到元素上时调用,而且只调用一次。这时候你可以做一些初始化的操作,比如设置一些默认值、添加事件监听器之类的。
  • 使用场景:当你需要在指令绑定到元素时就进行一些初始化操作,就可以用 bind 钩子函数。
// 自定义一个名为 'focus' 的指令
Vue.directive('focus', {
  // bind 钩子函数,在指令第一次绑定到元素时调用
  bind: function (el) {
    // 给元素添加一个自定义属性,用于标记这个元素被绑定了 focus 指令
    el.setAttribute('data-focus', 'true');
    // 打印一条消息,提示指令已经绑定到元素上
    console.log('指令已绑定到元素上');
  }
});

// 创建一个 Vue 实例
new Vue({
  el: '#app',
  template: '<input v-focus>'
});

2.inserted钩子函数

  • 作用inserted 钩子函数会在绑定元素被插入到父节点时调用。注意,这里的父节点必须是存在于 DOM 中的。
  • 使用场景:当你需要在元素插入到 DOM 后做一些操作,比如自动聚焦、添加动画效果等,就可以用 inserted 钩子函数。
// 自定义一个名为 'focus' 的指令
Vue.directive('focus', {
  // inserted 钩子函数,在绑定元素被插入到父节点时调用
  inserted: function (el) {
    // 让元素自动获得焦点
    el.focus();
    // 打印一条消息,提示元素已经插入到 DOM 中
    console.log('元素已插入到 DOM 中');
  }
});

// 创建一个 Vue 实例
new Vue({
  el: '#app',
  template: '<input v-focus>'
});

3.update钩子函数

  • 作用update 钩子函数会在包含组件的 VNode 更新时调用,但可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。
  • 使用场景:当你需要在组件更新时对指令绑定的元素做一些操作,就可以用 update 钩子函数。
// 自定义一个名为 'highlight' 的指令
Vue.directive('highlight', {
  // update 钩子函数,在包含组件的 VNode 更新时调用
  update: function (el, binding) {
    // 获取指令的值
    const color = binding.value;
    // 设置元素的背景颜色为指令的值
    el.style.backgroundColor = color;
    // 打印一条消息,提示元素的背景颜色已更新
    console.log('元素的背景颜色已更新');
  }
});

// 创建一个 Vue 实例
new Vue({
  el: '#app',
  data: {
    // 定义一个变量,用于存储背景颜色
    highlightColor: 'yellow'
  },
  template: '<div v-highlight="highlightColor">这是一个高亮的 div</div>'
});

4.componentUpdated钩子函数

  • 作用componentUpdated 钩子函数会在包含组件的 VNode 及其子 VNode 全部更新后调用。
  • 使用场景:当你需要在组件和其子组件都更新完成后对指令绑定的元素做一些操作,就可以用 componentUpdated 钩子函数。
// 自定义一个名为 'highlight' 的指令
Vue.directive('highlight', {
  // componentUpdated 钩子函数,在包含组件的 VNode 及其子 VNode 全部更新后调用
  componentUpdated: function (el, binding) {
    // 获取指令的值
    const color = binding.value;
    // 设置元素的背景颜色为指令的值
    el.style.backgroundColor = color;
    // 打印一条消息,提示元素的背景颜色已在组件更新后更新
    console.log('元素的背景颜色已在组件更新后更新');
  }
});

// 创建一个 Vue 实例
new Vue({
  el: '#app',
  data: {
    // 定义一个变量,用于存储背景颜色
    highlightColor: 'yellow'
  },
  template: '<div v-highlight="highlightColor">这是一个高亮的 div</div>'
});

5.unbind钩子函数

  • 作用unbind 钩子函数会在指令与元素解绑时调用,而且只调用一次。这时候你可以做一些清理工作,比如移除事件监听器。
  • 使用场景:当你需要在指令与元素解绑时做一些清理工作,就可以用 unbind 钩子函数。
// 自定义一个名为 'click-outside' 的指令
Vue.directive('click-outside', {
  // bind 钩子函数,在指令第一次绑定到元素时调用
  bind: function (el, binding, vnode) {
    // 定义一个点击事件处理函数
    el.clickOutsideEvent = function (event) {
      // 判断点击事件是否发生在元素外部
      if (!(el === event.target || el.contains(event.target))) {
        // 如果点击事件发生在元素外部,调用指令绑定的方法
        vnode.context[binding.expression](event);
      }
    };
    // 给 document 添加点击事件监听器
    document.addEventListener('click', el.clickOutsideEvent);
  },
  // unbind 钩子函数,在指令与元素解绑时调用
  unbind: function (el) {
    // 移除 document 上的点击事件监听器
    document.removeEventListener('click', el.clickOutsideEvent);
    // 删除元素上的点击事件处理函数
    delete el.clickOutsideEvent;
    // 打印一条消息,提示指令已与元素解绑
    console.log('指令已与元素解绑');
  }
});

// 创建一个 Vue 实例
new Vue({
  el: '#app',
  methods: {
    // 定义一个方法,用于处理点击元素外部的事件
    handleClickOutside: function () {
      console.log('点击了元素外部');
    }
  },
  template: '<div v-click-outside="handleClickOutside">点击这个 div 外部试试</div>'
});

这些钩子函数能让你在不同的阶段对指令绑定的元素进行操作,大大增强了 Vue 指令的灵活性。你可以根据具体的需求选择合适的钩子函数来使用。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • vue项目代码格式规范设置参考指南

    vue项目代码格式规范设置参考指南

    这篇文章主要给大家介绍了关于vue3简单封装input组件和统一表单数据的相关资料,不管你学习哪一门编程语言,相信大家都会略化这一部分,需要的朋友可以参考下
    2022-05-05
  • 在Linux服务器上部署vue项目

    在Linux服务器上部署vue项目

    这篇文章介绍了在Linux服务器上部署vue项目的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-11-11
  • 解决vue3中使用echart报错:Cannot read properties of undefined (reading ‘type‘)

    解决vue3中使用echart报错:Cannot read properties of&n

    在Vue项目中使用Echarts进行数据可视化是非常常见的需求,然而有时候在引入Echarts的过程中可能会遇到报错,本文主要介绍了解决vue3中使用echart报错:Cannot read properties of undefined (reading ‘type‘),感兴趣的可以了解一下
    2024-01-01
  • Vue3实现组件拖拽实时预览功能

    Vue3实现组件拖拽实时预览功能

    这篇文章主要介绍了Vue3实现组件拖拽实时预览功能,对于组件拖拽预览,用户可以在含有各种功能组件的列表中,选择需要的组件进行拖拽,需要的朋友可以参考下
    2023-12-12
  • 解决vue使用echarts报错:Can't get DOM width or height. Please check dom.clientWidth and dom.clientHeight问题

    解决vue使用echarts报错:Can't get DOM width&nbs

    这篇文章主要介绍了解决vue使用echarts报错:Can't get DOM width or height. Please check dom.clientWidth and dom.clientHeight问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • vue-router命名路由和编程式路由传参讲解

    vue-router命名路由和编程式路由传参讲解

    今天小编就为大家分享一篇关于vue-router命名路由和编程式路由传参讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-01-01
  • 在vue中使用防抖和节流,防止重复点击或重复上拉加载实例

    在vue中使用防抖和节流,防止重复点击或重复上拉加载实例

    今天小编就为大家分享一篇在vue中使用防抖和节流,防止重复点击或重复上拉加载实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-11-11
  • vue利用全局导航守卫作登录后跳转到未登录前指定页面的实例代码

    vue利用全局导航守卫作登录后跳转到未登录前指定页面的实例代码

    这篇文章主要介绍了vue利用全局导航守卫作登录后跳转到未登录前指定页面,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • vue项目实现按钮可随意移动

    vue项目实现按钮可随意移动

    这篇文章主要为大家详细介绍了vue项目实现按钮可随意移动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • vue-router next(false) 禁止访问某个页面时,不保留历史访问记录问题

    vue-router next(false) 禁止访问某个页面时,不保留历史访问记录问题

    这篇文章主要介绍了vue-router next(false) 禁止访问某个页面时,不保留历史访问记录问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11

最新评论