vue自定义指令

1. 概述

Vue.js 提供了自定义指令(Directives)的特性,允许开发者自定义 HTML 标签的行为。自定义指令是 Vue 的一种高级特性,它使你可以扩展 HTML 标签的行为。通过自定义指令,你可以添加、修改或删除元素的某些行为。

vue存在许多的内置指令:如:v-html、v-model、v-for 等等。

那么如何进行自定义指令呢?详见后面

2. 自定义指令

你可以在全局范围内或组件内部注册自定义指令。

全局注册的指令会影响到该 Vue 实例下的所有组件,而局部注册的指令只影响特定的组件。

2.1 全局注册

在main.js 中进行注册

语法如下:

js 复制代码
// 全局注册  
Vue.directive('指令名', {  
  inserted (el, binding) {  
    // 指令的逻辑  
    el.focus()
  },
  update (el, binding) {
    // 当绑定的值改变时更新预览 div(双向绑定)  
  },  
})  
  • el: 目标元素,你可以在其上直接操作 DOM。
  • binding : 一个对象,用于接收绑定,需要处理的数据,详见后续讲解

2.2 局部注册

在对应组件中进行注册

语法如下:

js 复制代码
// 组件内注册  
export default {
  
  // 局部注册
  directives: {  
    '指令名': {  
     inserted (el, binding) {  
          // 指令的逻辑  
          el.focus()
      },
      update (el, binding) {
    		// 当绑定的值改变时更新预览 div(双向绑定)  
 		 },  
    }  
  }  
  
}
  • el: 目标元素,你可以在其上直接操作 DOM。
  • binding : 一个对象,用于接收绑定,需要处理的数据,详见后续讲解

3. 自定义组件的使用

如下:案例

js 复制代码
<input v-指令名 type="text">
相关推荐
Doris8936 分钟前
【JS】Web APIs BOM与正则表达式详解
前端·javascript·正则表达式
建南教你种道德之花6 分钟前
浏览器缓存完全指南:从原理到实践
前端
南游6 分钟前
后台计时器罢工?我改用visibilitychange监听,代码从此‘永不停机’!
javascript
晚霞的不甘13 分钟前
实战进阶:构建高性能、高可用的 Flutter + OpenHarmony 车载 HMI 系统
开发语言·javascript·flutter
1024小神13 分钟前
swiftui中view分为几种类型?各有什么特点
前端
网络点点滴19 分钟前
pinia简介
开发语言·javascript·vue.js
局i20 分钟前
v-for 与 v-if 的羁绊:Vue 中列表渲染与条件判断的爱恨情仇
前端·javascript·vue.js
suke20 分钟前
紧急高危:Next.js 曝出 CVSS 10.0 级 RCE 漏洞,请立即修复!
前端·程序员·next.js
狮子座的男孩23 分钟前
js函数高级:06、详解闭包(引入闭包、理解闭包、常见闭包、闭包作用、闭包生命周期、闭包应用、闭包缺点及解决方案)及相关面试题
前端·javascript·经验分享·闭包理解·常见闭包·闭包作用·闭包生命周期