Vue--》自定义指令的使用讲解
创始人
2024-03-24 02:42:29
0

目录

自定义指令

自定义指令的分类

私有自定义指令:

全局自定义指令:

总结


自定义指令

vue官方提供了v-text、v-for、v-model、v-if等常用的指令,还允许开发者自定义指令。

自定义指令的分类

私有自定义指令

在每个vue组件中,可以在directives节点下声明私有自定义指令。代码如下:

注意:directives节点下定义的指令名称必须是要渲染标签样式的 v-指令的v-后面的名称。

bind函数

指令与元素成功绑定时执行bind函数。




当然我们也可以为自定义指令赋予静态值和动态值。如下:




inserted函数

指令所在元素被插入页面时调用。


update函数

bind函数只调用1次,也就是说:当指令第一次绑定到元素时调用,当DOM更新时bind函数不会被触发。updated函数会在每次DOM更新时被调用。代码如下:




注意:bind函数和update函数两者的区别是bind函数是第一次被执行往后都不执行了,而update函数是第一次不执行,往后都执行,所以两者是都需要的,不能只写一个。

函数简写

如果 bind 和 update 函数中的逻辑完全相同,则对象格式的自定义指令可以简写为函数格式:

// 私有自定义指令节点
directives:{color(el,binding){el.style.color = binding.value}
},

全局自定义指令

全局共享的自定义指令需要通过 Vue.directive() 进行声明,代码如下:注意:全局声明的自定义指令或者说之前讲解的全局声明的过滤器都要放到 main.js 中去声明。

import Vue from 'vue'
import App from './App.vue'Vue.config.productionTip = false// 全局自定义指令
Vue.directive('color',function(el,binding){el.style.color = binding.value
})// 创建 Vue 的实例对象
new Vue({// 把render函数指定的组件,渲染到 HTML 页面中。render: h => h(App),
}).$mount('#app')

总结

定义语法:

1)局部指令

new Vue({ directives:{指令名:配置对象} }) 或 new Vue({ directives:{指令名:回调函数} })

2)全局指令

Vue.directive(指令名,配置对象) 或 Vue.directive(指令名,回调函数)

配置对象中常用的3个回调

1、bind指令:指令与元素绑定时使用

2、inserted指令:指令所在元素被插入页面时使用

3、update指令:所在模板结构被重新解析时使用

3)注意

1、指令定义时不加 v- ,但使用时要加 v-

2、指令名如果是多个单词,要使用kebab-case命名方式,例:v-big-house

相关内容

热门资讯

不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
安卓文字转语音tts没有声音 安卓文字转语音TTS没有声音的问题在应用中比较常见,通常是由于一些设置或者代码逻辑问题导致的。本文将...
APK正在安装,但应用程序列表... 这个问题可能是由于以下原因导致的:应用程序安装的APK文件可能存在问题。设备上已经存在同名的应用程序...
报告实验.pdfbase.tt... 这个错误通常是由于找不到字体文件或者文件路径不正确导致的。以下是一些解决方法:确认字体文件是否存在:...