【VUE】Vue2中的自定义指令

在 Vue2 中,我们可以使用 Vue.directive 函数来定义自定义指令。自定义指令用于对 DOM 操作的封装和复用。

在 Vue2 中,自定义指令的生命周期钩子函数的功能分别如下:

  • bind: 只调用一次,在指令第一次绑定到元素时调用,用于进行一次性的初始化设置。
  • inserted: 被绑定元素插入父节点时调用,用于进行 DOM 操作。
  • update: 被绑定元素所在的模板更新时调用,而无论绑定值是否变化,以及何时发生变化都会调用。
  • componentUpdated: 被绑定元素所在模板完成一个周期的更新时调用,只要组件数据变化,就会调用。
  • unbind: 只调用一次,在指令解绑时调用,用于清除所有的绑定指令。

常用的自定义指令场景:

  1. v-focus:实现页面加载后自动聚焦到某个表单元素上。
  2. v-limit:限制表单输入框的输入长度,对于超出长度的字符提供错误提示。
  3. v-ellipsis:处理文本溢出的情况,通过省略号的形式显示文本,当用户鼠标悬停在省略号上时显示完整文本内容。
  4. v-scroll:在页面需要滚动操作时,当滚动到特定位置或高度时,显示浮动操作按钮或菜单进行快捷操作。
  5. v-drag:实现拖拽功能,当用户在指定的区域按下鼠标时,可以移动元素到指定的位置。
  6. v-lazy-img:图片懒加载,当图片未出现在用户可视区域内时,不进行请求和加载,当图片出现在用户可视区域内时,进行请求和加载。
  7. v-toggle:实现开关切换功能,当用户点击开关时,改变指定元素的显示状态。
  8. v-tooltip:鼠标悬停在某个元素上时,显示 tooltip 或 popover 提示框。
相关推荐
折果42 分钟前
如何在vue项目中封装自己的全局message组件?一步教会你!
前端·面试
不死鸟.亚历山大.狼崽子1 小时前
Syntax Error: Error: PostCSS received undefined instead of CSS string
前端·css·postcss
汪子熙1 小时前
Vite 极速时代的构建范式
前端·javascript
叶常落1 小时前
[react] js容易混淆的两种导出方式2025-08-22
javascript
跟橙姐学代码1 小时前
一文读懂 Python 的 JSON 模块:从零到高手的进阶之路
前端·python
前端小巷子1 小时前
Vue3的渲染秘密:从同步批处理到异步微任务
前端·vue.js·面试
nightunderblackcat2 小时前
新手向:用FastAPI快速构建高性能Web服务
前端·fastapi
每天学习一丢丢2 小时前
SpringBoot + Vue实现批量导入导出功能的标准方案
vue.js·spring boot·后端
小码编匠2 小时前
物联网数据大屏开发效率翻倍:Vue + DataV + ECharts 的标准化模板库
前端·vue.js·echarts
欧阳天风3 小时前
分段渲染加载页面
前端·fcp