位置: IT常识 - 正文

vue2.x与vue3.x中自定义指令详解(vue2vue3的区别)

编辑:rootadmin
vue2.x与vue3.x中自定义指令详解

推荐整理分享vue2.x与vue3.x中自定义指令详解(vue2vue3的区别),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue2.x和vue3.x的区别,vue3和vue2求区别,vue3和2的区别,vue2与3的区别,vue2.x和vue3.x的区别,vue2与3的区别,vue2与3的区别,vue2与3的区别,内容如对您有帮助,希望把文章链接给更多的朋友!

🐱 个人主页:不叫猫先生 🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀! 💫系列专栏:vue3从入门到精通、TypeScript从入门到实践 📢 资料领取:前端进阶资料以及文中源码可以找我免费领取 🔥 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,互相交流学习,期待你的加入!(文末有我wx或者直接私信)

🍬目录🌮前言🥙一、自定义指令分类🥪二、Vue2.x自定义指令钩子函数(1)bind与update区别(2)update与componentUpdated区别(3)钩子函数的参数(摘自官网)(4)局部自定义指令(5)全局自定义指令(6)简写形式🍔 三、Vue3.x自定义指令钩子函数(1)指令钩子函数(摘自官网)(2)钩子函数参数(3)局部注册两种方式(4)全局注册(5)简化形式🌮前言

vue自定义指令(2.x丨3.x)可以帮助我们实现需要操作,比如防抖、节流、懒加载、输入框自动聚焦等等,使用起来非常方便,比如vue自带的v-text、v-html、v-show、v-if等等。

🥙一、自定义指令分类局部自定义指令:只在组件内有效全局自定义指令:所有组件都有效🥪二、Vue2.x自定义指令钩子函数

bind:只会调用一次,指令 第一次 绑定到元素时会调用

inserted:被绑定元素插入父节点时调用 。

update:元素第一次绑定不会触发,绑定的值发生更新触发,可能发生在其子节点更新之前。

componentUpdated:指令所在组件的 VNode 及其子 VNode 全部更新后调用。

unbind:只调用一次,指令与元素解绑时调用。

(1)bind与update区别vue2.x与vue3.x中自定义指令详解(vue2vue3的区别)

相同点:

dom插入都会调用,bind在inserted之前

异同点:

bind 时父节点为 nullinserted 时父节点存在bind是在dom树绘制前调用,inserted在dom树绘制后调用(2)update与componentUpdated区别组件更新都会调用,update在componentUpdated之前update 组件更新前的状态,componentUpdated 组件更新后的状态Vue.directive('focus', { inserted: function (el) { console.log(el.parentNode, 'inserted') el.focus(); }, bind: function (el) { console.log(el.parentNode, 'bind') el.focus(); },});

输出结果如下,说明执行bind时,还没父节点;执行inserted时,已有父节点。

(3)钩子函数的参数(摘自官网)el:指令所绑定的元素,可以用来直接操作 DOM。binding:一个对象,包含以下 property:name:指令名,不包括 v- 前缀。value:指令的绑定值,例如:v-my-directive=“1 + 1” 中,绑定值为 2。oldValue:指令绑定的前一个值,仅在 update 和 componentUpdated 钩子中可用。无论值是否改变都可用。expression:字符串形式的指令表达式。例如 v-my-directive=“1 + 1” 中,表达式为 “1 + 1”。arg:传给指令的参数,可选。例如 v-my-directive:foo 中,参数为 “foo”。modifiers:一个包含修饰符的对象。例如:v-my-directive.foo.bar 中,修饰符对象为 { foo: true, bar: true }。vnode:Vue 编译生成的虚拟节点。移步 VNode API 来了解更多详情。oldVnode:上一个虚拟节点,仅在 update 和 componentUpdated 钩子中可用。 <p v-style:[direction]="connect">Enter connection information to connect</p> directives: { style: { bind(el,binding) { console.log(binding,'binding') el.style.fontSize = "30px"; el.style.color = "blue"; }, }, },

(4)局部自定义指令

在组件A.vue,用自定义指令实现改变文字颜色

<p v-style>文字描述</p> directives: { style: { bind(el,binding) { el.style.fontSize = "30px"; el.style.color = "blue"; }, update(el,binding){ el.style.fontSize = "30px"; el.style.color = "blue"; } }, },style:指令的名称,使用的时候要加前面加个v-bind:只会调用一次,指令 第一次 绑定到元素时会调用el:是指绑定的这个dom元素本身binding:获取绑定指令的信息(name:指令名称;rawName:指令全称:value:指定绑定的值)update:元素第一次绑定不会触发,绑定的值发生更新触发,参数与binding是相同的,如果逻辑与bind相同的话可以直接把指令当成函数写,上面的指令是对象类型。v-style:使用指令改变了元素的样式(5)全局自定义指令

使用Vue.directive(‘指令名称’,{钩子函数})

第一个参数为字符串,指令的名称第二个参数是一个对象,用于接收指令的参数值Vue.directive('style',{ bind(el) { el.style.fontSize = "30px"; el.style.color = "blue"; }, },)(6)简写形式

如果update逻辑与bind相同的话可以直接把指令当成函数写

directives: { style(){ el.style.fontSize = "30px"; el.style.color = "blue"; }, },🍔 三、Vue3.x自定义指令钩子函数(1)指令钩子函数(摘自官网)const myDirective = { // 在绑定元素的 attribute 前 // 或事件监听器应用前调用 created(el, binding, vnode, prevVnode) { // 下面会介绍各个参数的细节 }, // 在元素被插入到 DOM 前调用 beforeMount(el, binding, vnode, prevVnode) {}, // 在绑定元素的父组件 // 及他自己的所有子节点都挂载完成后调用 mounted(el, binding, vnode, prevVnode) {}, // 绑定元素的父组件更新前调用 beforeUpdate(el, binding, vnode, prevVnode) {}, // 在绑定元素的父组件 // 及他自己的所有子节点都更新后调用 updated(el, binding, vnode, prevVnode) {}, // 绑定元素的父组件卸载前调用 beforeUnmount(el, binding, vnode, prevVnode) {}, // 绑定元素的父组件卸载后调用 unmounted(el, binding, vnode, prevVnode) {}}(2)钩子函数参数

指令的钩子会传递以下几种参数:

el:指令绑定到的元素。这可以用于直接操作 DOM。

binding:一个对象,包含以下属性。 value:传递给指令的值。例如在 v-my-directive=“1 + 1” 中,值是 2。 oldValue:之前的值,仅在 beforeUpdate 和 updated 中可用。无论值是否更改,它都可用。 arg:传递给指令的参数 (如果有的话)。例如在 v-my-directive:foo 中,参数是 “foo”。 modifiers:一个包含修饰符的对象 (如果有的话)。例如在 v-my-directive.foo.bar 中,修饰符对象是 { foo: true, bar: true }。 instance:使用该指令的组件实例。 dir:指令的定义对象。

vnode:代表绑定元素的底层 VNode。

prevNode:之前的渲染中代表指令所绑定元素的 VNode。仅在 beforeUpdate 和 updated 钩子中可用。

(3)局部注册两种方式<script lang="ts" setup>// 局部指令, 变量名为驼峰命名(vFocus = v-focus)const vFocus = { mounted: (el:any) => { el.focus() console.log(el, '已经自动获得焦点') }}</script><script lang="ts">const vFocus = { focus: { mounted(el:any){ el.focus(); console.log(el, "已经自动获得焦点"); } },};export default { setup() { }, directives: vFocus,};</script>(4)全局注册组件A.vue <input type="text" v-focus>在directives文件夹新建focus.ts文件const directives: any = {mounted(el: any) {el.focus();el.value = '1'}}export default {name: "focus",directives}在directives文件夹新建index.jsimport type { App } from 'vue'import focus from './focus'export default function installDirective(app: App) { app.directive(focus.name, focus.directives);} main.ts文件import directives from './directives'const app = createApp(App);app.use(directives);(5)简化形式

当update和mounted中的函数体一样时,则可以简写成如下:

const directives = (el:any) => {el.focus();el.value = '1';}export default {name: "focus",directives}
本文链接地址:https://www.jiuchutong.com/zhishi/299691.html 转载请保留说明!

上一篇:第一次尝试制作一个钓鱼网站,小白教程,超细!(我初次尝试制作的英文怎么写)

下一篇:【tensorflow】制作自己的数据集(tensorflow gui)

  • 如何编辑pdf文件(wps office如何编辑pdf文件)

    如何编辑pdf文件(wps office如何编辑pdf文件)

  • .cn是什么文件(cnv是什么文件)

    .cn是什么文件(cnv是什么文件)

  • 为什么设置了骚扰拦截还是能收到信息(为什么设置了骚扰电话拦截还能打进来)

    为什么设置了骚扰拦截还是能收到信息(为什么设置了骚扰电话拦截还能打进来)

  • 闲鱼h价是什么意思(闲鱼的价格和原价有什么区别)

    闲鱼h价是什么意思(闲鱼的价格和原价有什么区别)

  • 联想电脑白屏了按哪个键可以修复(联想电脑白屏了按F8无反应)

    联想电脑白屏了按哪个键可以修复(联想电脑白屏了按F8无反应)

  • iphone转接头失灵(苹果转接头失灵)

    iphone转接头失灵(苹果转接头失灵)

  • 华为测量工具在哪(华为手机测量工具软件)

    华为测量工具在哪(华为手机测量工具软件)

  • 抖音红心多了有啥用(抖音红心数量)

    抖音红心多了有啥用(抖音红心数量)

  • wifi没网络是什么情况(wifi没网络是什么)

    wifi没网络是什么情况(wifi没网络是什么)

  • 一个路由器可以连接多少手机(一个路由器可以接两条宽带吗?)

    一个路由器可以连接多少手机(一个路由器可以接两条宽带吗?)

  • 小米9发热严重是怎么回事(小米发热严重怎么设置)

    小米9发热严重是怎么回事(小米发热严重怎么设置)

  • 苹果手机灵敏度怎么调(苹果手机灵敏度在哪里设置)

    苹果手机灵敏度怎么调(苹果手机灵敏度在哪里设置)

  • 微信屏幕突然变黑了怎么办(微信屏幕突然变黑了)

    微信屏幕突然变黑了怎么办(微信屏幕突然变黑了)

  • qq的人脸识别有什么用(qq上人脸识别)

    qq的人脸识别有什么用(qq上人脸识别)

  • 开过情侣空间有记录吗(开过情侣空间有什么好处)

    开过情侣空间有记录吗(开过情侣空间有什么好处)

  • 手机自动锁屏怎么设置(手机自动锁屏怎么办)

    手机自动锁屏怎么设置(手机自动锁屏怎么办)

  • iphonex指纹解锁在哪(iphonex 指纹识别)

    iphonex指纹解锁在哪(iphonex 指纹识别)

  • 闹钟响了怎么关(闹钟响了怎么关(不是手机闹钟))

    闹钟响了怎么关(闹钟响了怎么关(不是手机闹钟))

  • 手机耳机话筒怎么在电脑用(手机耳机话筒怎么接线)

    手机耳机话筒怎么在电脑用(手机耳机话筒怎么接线)

  • 腾讯校友网怎么没了(腾讯校友录登录)

    腾讯校友网怎么没了(腾讯校友录登录)

  • 三星note9防水吗(三星note9防水胶怎么贴)

    三星note9防水吗(三星note9防水胶怎么贴)

  • 怎么将QQ达人天数屏蔽(怎么将qq达人天数关掉)

    怎么将QQ达人天数屏蔽(怎么将qq达人天数关掉)

  • 花椒直播如何保存回放(花椒直播如何保存到相册)

    花椒直播如何保存回放(花椒直播如何保存到相册)

  • mac怎么卸载软件 mac系统卸载程序方法图解(mac怎么卸载软件core sync)

    mac怎么卸载软件 mac系统卸载程序方法图解(mac怎么卸载软件core sync)

  • 亏损企业股权转让
  • 企业从银行借款归还应付账款
  • 文化创意服务的税率
  • 个体工商户2023年税收政策
  • 视同销售要确认收入吗?
  • 可税前扣除的工资
  • 农产品加计扣除政策2023最新
  • 计提工资数大于实际支付数怎么办?
  • 标书费收据丢失怎么办
  • 受托加工物资如何做账
  • 补提以前年度个税会计分录
  • 土地使用税是由出租方还是承租方交
  • 税务局开具无违规证明
  • 其他应收款在资产负债表中是负数
  • 违约金收税吗
  • 公司老板垫付的钱怎么做账
  • 分支机构能否核定企业所得税
  • 上报汇总完成,远程清卡清不了
  • 增值税普票当月开错了怎么办
  • 理财认购申购
  • 1000元的打印机双十一满减可以减150吗少
  • 固定资产减值测试时预计其未来现金流量不应考虑的因素
  • 招待费的住宿费可以抵扣吗
  • 上市公司发行股票会计分录
  • php快速查找
  • 更新kb4584229
  • w11怎么创建快捷方式
  • 周转材料摊销是什么科目
  • 无形资产的会计处理
  • vue set-cookie
  • php模板教程
  • 分次预缴税额怎么算
  • php cookie session
  • 使用sm4js进行加密和国密sm4的总结
  • python 二值化
  • 营业外收入会计分录怎么做
  • 每个月工资扣的税为什么不一样
  • 现金流量风险怎么解决
  • 纳税人兼营不同税率
  • 公对公账号没有卡能取得出来钱吗
  • 织梦cms官网
  • 项目支出可以列办公费吗
  • SqlServer 2005 T-SQL Query 学习笔记(4)
  • sql2005安装步骤
  • MySQL数据库远程登录
  • 城市维护建设税属于中央还是地方
  • 社保的账务处理分录
  • 无形资产的成本包括增值税吗
  • 内帐收入怎么确定
  • 专利代理服务费如何记账
  • 研发费用账务调整合同怎么写
  • 年化收益率怎么算收益率
  • 新开立银行账户怎么办理
  • 固定资产没有发票
  • 收承兑汇票的利息怎么算
  • 外经证是怎么样的
  • 已计提教育费附加但是未扣除个税
  • 公司基本账户提现规定
  • 客户付了订金后能退吗
  • 金税盘发票认证怎么操作流程
  • 赠送的产品价格为0怎么做账
  • 小加工厂怎么开发票
  • 汽车贷款利息计算公式计算器
  • 会计账簿的含义及其作用
  • mysql工作内容
  • linux常用命令sed
  • vmware12安装教程图解
  • 操作系统运行慢怎么解决
  • service.exe是什么
  • centos7搭建frp
  • kwconfig.exe
  • windows8截图保存在哪里
  • cocos2dx4.0教程
  • unity3d官方
  • window批处理
  • nodejsorg
  • JQuery解析XML的方法小结
  • jquery兼容ie
  • 地方税务局怎么查企业信息
  • 转卖车辆车船税多少
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设