当前位置:首页 > VUE

vue指令实现

2026-01-08 01:50:46VUE

Vue 指令的实现方式

Vue 指令是特殊的标记,用于在 DOM 元素上应用特定的行为。可以通过全局或局部方式注册自定义指令。

全局注册指令

在 Vue 应用中通过 Vue.directive 方法全局注册指令:

Vue.directive('focus', {
  inserted: function (el) {
    el.focus()
  }
})

使用指令时在模板中添加 v-focus

<input v-focus>

局部注册指令

在组件选项中通过 directives 属性局部注册指令:

vue指令实现

export default {
  directives: {
    focus: {
      inserted: function (el) {
        el.focus()
      }
    }
  }
}

指令钩子函数

自定义指令可以包含以下钩子函数:

  • bind:指令第一次绑定到元素时调用
  • inserted:被绑定元素插入父节点时调用
  • update:所在组件的 VNode 更新时调用
  • componentUpdated:所在组件及子组件 VNode 全部更新后调用
  • unbind:指令与元素解绑时调用
Vue.directive('demo', {
  bind: function (el, binding, vnode) {
    // 初始化设置
  },
  update: function (el, binding, vnode) {
    // 根据绑定值的变化更新行为
  }
})

指令参数

钩子函数接收以下参数:

  • el:指令绑定的元素
  • binding:包含指令信息的对象
  • vnode:Vue 编译生成的虚拟节点

binding 对象包含以下属性:

vue指令实现

  • name:指令名(不包含 v- 前缀)
  • value:指令的绑定值
  • oldValue:指令绑定的前一个值
  • expression:字符串形式的指令表达式
  • arg:传给指令的参数
  • modifiers:包含修饰符的对象

动态指令参数

指令的参数可以是动态的:

<div v-demo:[direction]="200"></div>
Vue.directive('demo', {
  bind: function (el, binding) {
    // direction 将作为 binding.arg 传递
    el.style.position = 'fixed'
    const s = binding.arg || 'top'
    el.style[s] = binding.value + 'px'
  }
})

函数简写

当需要在 bindupdate 中触发相同行为时,可以使用简写函数:

Vue.directive('color', function (el, binding) {
  el.style.color = binding.value
})

对象字面量

如果指令需要多个值,可以传入对象字面量:

<div v-demo="{ color: 'white', text: 'hello' }"></div>
Vue.directive('demo', function (el, binding) {
  console.log(binding.value.color) // "white"
  console.log(binding.value.text)  // "hello"
})

标签: 指令vue
分享给朋友:

相关文章

vue实现文字播放栏

vue实现文字播放栏

Vue 实现文字播放栏(跑马灯效果) 方法一:使用 CSS 动画 + Vue 数据绑定 通过 CSS 的 @keyframes 实现动画效果,结合 Vue 的动态数据绑定控制内容。 <tem…

vue如何实现到期提醒

vue如何实现到期提醒

实现 Vue 到期提醒功能 使用计算属性计算剩余时间 在 Vue 组件中定义一个计算属性,计算目标日期与当前日期的差值。通过 Date 对象获取时间戳并计算剩余天数或小时数。 computed:…

vue实现收起展开面板

vue实现收起展开面板

实现收起展开面板的方法 在Vue中实现收起展开面板功能可以通过多种方式完成,以下是几种常见的实现方法: 使用v-show或v-if控制显示隐藏 利用Vue的指令可以轻松实现面板的展开和收起:…

vue实现全局遮罩层

vue实现全局遮罩层

实现全局遮罩层的方法 在Vue中实现全局遮罩层可以通过多种方式完成,以下是几种常见的实现方法: 使用Vue组件创建遮罩层 创建一个遮罩层组件,通过全局注册或动态挂载的方式实现全局调用。以下是一个简单…

vue公共列表的实现

vue公共列表的实现

实现 Vue 公共列表组件 公共列表组件通常用于展示重复结构的数据,例如商品列表、用户列表等。以下是一个典型的实现方式: 基础实现 创建可复用的列表组件 List.vue: <tem…

vue实现签约合作弹窗

vue实现签约合作弹窗

实现签约合作弹窗的步骤 使用Vue实现签约合作弹窗可以通过组件化方式完成,结合模态框和表单交互逻辑。以下是具体实现方法: 1. 创建弹窗组件 新建一个Vue组件文件(如SignContractDi…