当前位置:首页 > VUE

单独实现vue指令

2026-02-18 20:11:19VUE

实现自定义 Vue 指令

Vue 允许注册自定义指令,用于对普通 DOM 元素进行底层操作。以下是实现自定义指令的步骤。

全局注册指令

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

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

使用时直接在元素上添加 v-focus

<input v-focus>

局部注册指令

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

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

指令钩子函数

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

  • bind:指令第一次绑定到元素时调用
  • inserted:被绑定元素插入父节点时调用
  • update:所在组件的 VNode 更新时调用
  • componentUpdated:所在组件及子组件 VNode 更新后调用
  • unbind:指令与元素解绑时调用

钩子函数参数

每个钩子函数接收以下参数:

  • el:指令绑定的 DOM 元素
  • binding:包含以下属性的对象:
    • name:指令名(不含 v- 前缀)
    • value:指令的绑定值
    • oldValue:指令绑定的前一个值
    • expression:字符串形式的指令表达式
    • arg:传给指令的参数
    • modifiers:包含修饰符的对象
  • vnode:Vue 编译生成的虚拟节点
  • oldVnode:上一个虚拟节点

动态指令参数

指令参数可以是动态的:

<div v-demo:[argument]="value"></div>

argument 会根据组件实例数据进行更新。

对象字面量

指令可以接收对象字面量:

<div v-demo="{ color: 'white', text: 'hello' }"></div>

在指令中通过 binding.value.colorbinding.value.text 访问。

示例:实现 v-color 指令

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

使用方式:

<p v-color="'red'">这段文字会显示为红色</p>

示例:实现 v-pin 指令

Vue.directive('pin', {
  bind: function (el, binding) {
    el.style.position = 'fixed'
    const s = binding.arg || 'top'
    el.style[s] = binding.value + 'px'
  },
  update: function (el, binding) {
    const s = binding.arg || 'top'
    el.style[s] = binding.value + 'px'
  }
})

使用方式:

<p v-pin:bottom="200">固定在距底部200像素处</p>

注意事项

  1. 指令名称应避免与 Vue 内置指令冲突
  2. 指令应该专注于 DOM 操作,避免包含复杂的业务逻辑
  3. updatecomponentUpdated 钩子中,父组件可能还未更新
  4. 指令可以复用,应保持功能单一性

通过合理使用自定义指令,可以封装 DOM 操作,使代码更加简洁和可维护。

单独实现vue指令

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

相关文章

vue实现本地数据存储

vue实现本地数据存储

使用 localStorage 或 sessionStorage Vue 中可以直接调用浏览器提供的 localStorage 或 sessionStorage API 进行数据存储。localSto…

vue设计与实现目录

vue设计与实现目录

以下是《Vue设计与实现》一书的典型目录结构(根据常见技术书籍及Vue核心内容整理): 响应式系统 响应式数据的基本原理 依赖收集与触发更新 实现简易响应式系统 Proxy与Reflec…

vue实现下拉框删除

vue实现下拉框删除

Vue 实现下拉框删除功能 在Vue中实现下拉框的删除功能通常涉及以下步骤: 数据绑定与渲染 在Vue组件中定义数据数组用于存储下拉框选项: data() { return {…

vue实现拖放

vue实现拖放

Vue 实现拖放功能 Vue 中实现拖放功能通常可以通过 HTML5 的原生拖放 API 或第三方库(如 vuedraggable)来实现。以下是两种方法的详细说明。 使用 HTML5 原生拖放…

vue实现删除

vue实现删除

Vue 实现删除功能的方法 在 Vue 中实现删除功能通常涉及以下几个步骤: 数据绑定与列表渲染 使用 v-for 指令渲染列表数据,并为每个项绑定唯一标识符(如 id)。例如: <ul…

vue实现前端

vue实现前端

Vue 实现前端的核心方法与步骤 安装 Vue 项目 使用 Vue CLI 或 Vite 创建项目。Vue CLI 是传统构建工具,Vite 是新一代轻量级工具。 npm init vue@l…