vue自定义指令详解

简介: vue自定义指令详解

什么是指令

  1. 在vue中我们看到的v-开头的行内属性,都是指令,不同的指令可以完成或实现不同的功能
    除了核心功能默认内置的指令 (v-model 和 v-show),Vue 也允许注册自定义指令

自定义指令

分类

  1. 全局自定义指令
  2. 私有自定义指令

自定义指令存在的钩子函数

  • bind:只调用一次,指令第一次绑定到元素时调用。在这里可以进行一次性的初始化设置
  • inserted:被绑定元素插入父节点时调用 (仅保证父节点存在,但不一定已被插入文档中)
  • update:所在组件的 VNode 更新时调用,但是可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。但是你可以通过比较更新前后的值来忽略不必要的模板更新
  • componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用
  • unbind:只调用一次,指令与元素解绑时调用

钩子函数的参数

  • el:指令所绑定的元素,可以用来直接操作 DOM
  • binding:一个对象,包含以下 property:
  • name:指令名,不包括 v- 前缀。
  • value:指令的绑定值,例如:v-img="{text:123}"那么binding.value.text=123
  • oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。
  • expression:字符串形式的指令表达式。
  • arg:传给指令的参数(可选)。
  • modifiers:一个包含修饰符的对象。
  • vnode:Vue编译生成的虚拟节点
  • oldVnode:上一个虚拟节点,尽在update和componentUpdated钩子中可用

如何实现(获取焦点功能)

全局实现

// 注册一个全局自定义指令 `v-focus` 
Vue.directive('focus', {
  // 当被绑定的元素插入到 DOM 中时……
  inserted: function (el) {
    // 聚焦元素
    el.focus()  // 页面加载完成之后自动让输入框获取到焦点的小功能
  }
})
// 使用方式
<input v-focus />

局部实现

directives: {
  focus: {
    // 指令的定义
    inserted: function (el) {
      el.focus() // 页面加载完成之后自动让输入框获取到焦点的小功能
    }
  }
}
// 使用方式
<input v-focus />

应用场景

  • 获取焦点
  • 表单防止重复提交
  • 图片懒加载
  • 拖拽指令
  • 页面水印等
目录
相关文章
|
2天前
|
存储 JavaScript 前端开发
搞懂Vue一篇文章就够了
搞懂Vue一篇文章就够了
9 0
|
2天前
|
JavaScript 前端开发 UED
Vue 异步组件
Vue 异步组件
10 0
|
2天前
|
JavaScript
Vue自定义指令的三个方法
Vue自定义指令的三个方法
7 0
|
2天前
|
存储 资源调度 JavaScript
vue引入vuex
vue引入vuex
25 7
|
2天前
|
JavaScript 前端开发
vue怎么自定义底部导航
vue怎么自定义底部导航
21 10
|
3天前
|
JavaScript 索引
vue 在什么情况下在数据发生改变的时候不会触发视图更新
vue 在什么情况下在数据发生改变的时候不会触发视图更新
15 2
|
3天前
|
存储 缓存 JavaScript
vue中性能优化
vue中性能优化
12 1
|
3天前
|
JavaScript
vue常用指令
vue常用指令
12 1
|
3天前
|
JavaScript
vue自定义指令
vue自定义指令
10 0
|
JavaScript 数据安全/隐私保护
Vue:几个实用的 Vue 自定义指令
Vue:几个实用的 Vue 自定义指令
85 0
Vue:几个实用的 Vue 自定义指令