Vue 中directive的钩子函数(bind、inserted 等)的作用及使用场景

大白话Vue 中directive的钩子函数(bind、inserted 等)的作用及使用场景。

在 Vue 里,指令(directive)是个超实用的东西,它能让你在不改动组件逻辑的情况下,给 HTML 元素添加一些特殊的行为。Vue 指令有好几个钩子函数,下面我就挨个给你讲讲这些钩子函数的作用和使用场景,还会附上带注释的代码示例。

1. bind 钩子函数

  • 作用bind 钩子函数会在指令第一次绑定到元素上时调用,而且只调用一次。这时候你可以做一些初始化的操作,比如设置一些默认值、添加事件监听器之类的。
  • 使用场景:当你需要在指令绑定到元素时就进行一些初始化操作,就可以用 bind 钩子函数。
// 自定义一个名为 'focus' 的指令
Vue.directive('focus', {// bind 钩子函数,在指令第一次绑定到元素时调用bind: function (el) {// 给元素添加一个自定义属性,用于标记这个元素被绑定了 focus 指令el.setAttribute('data-focus', 'true');// 打印一条消息,提示指令已经绑定到元素上console.log('指令已绑定到元素上');}
});// 创建一个 Vue 实例
new Vue({el: '#app',template: '<input v-focus>'
});

2. inserted 钩子函数

  • 作用inserted 钩子函数会在绑定元素被插入到父节点时调用。注意,这里的父节点必须是存在于 DOM 中的。
  • 使用场景:当你需要在元素插入到 DOM 后做一些操作,比如自动聚焦、添加动画效果等,就可以用 inserted 钩子函数。
// 自定义一个名为 'focus' 的指令
Vue.directive('focus', {// inserted 钩子函数,在绑定元素被插入到父节点时调用inserted: function (el) {// 让元素自动获得焦点el.focus();// 打印一条消息,提示元素已经插入到 DOM 中console.log('元素已插入到 DOM 中');}
});// 创建一个 Vue 实例
new Vue({el: '#app',template: '<input v-focus>'
});

3. update 钩子函数

  • 作用update 钩子函数会在包含组件的 VNode 更新时调用,但可能发生在其子 VNode 更新之前。指令的值可能发生了改变,也可能没有。
  • 使用场景:当你需要在组件更新时对指令绑定的元素做一些操作,就可以用 update 钩子函数。
// 自定义一个名为 'highlight' 的指令
Vue.directive('highlight', {// update 钩子函数,在包含组件的 VNode 更新时调用update: function (el, binding) {// 获取指令的值const color = binding.value;// 设置元素的背景颜色为指令的值el.style.backgroundColor = color;// 打印一条消息,提示元素的背景颜色已更新console.log('元素的背景颜色已更新');}
});// 创建一个 Vue 实例
new Vue({el: '#app',data: {// 定义一个变量,用于存储背景颜色highlightColor: 'yellow'},template: '<div v-highlight="highlightColor">这是一个高亮的 div</div>'
});

4. componentUpdated 钩子函数

  • 作用componentUpdated 钩子函数会在包含组件的 VNode 及其子 VNode 全部更新后调用。
  • 使用场景:当你需要在组件和其子组件都更新完成后对指令绑定的元素做一些操作,就可以用 componentUpdated 钩子函数。
// 自定义一个名为 'highlight' 的指令
Vue.directive('highlight', {// componentUpdated 钩子函数,在包含组件的 VNode 及其子 VNode 全部更新后调用componentUpdated: function (el, binding) {// 获取指令的值const color = binding.value;// 设置元素的背景颜色为指令的值el.style.backgroundColor = color;// 打印一条消息,提示元素的背景颜色已在组件更新后更新console.log('元素的背景颜色已在组件更新后更新');}
});// 创建一个 Vue 实例
new Vue({el: '#app',data: {// 定义一个变量,用于存储背景颜色highlightColor: 'yellow'},template: '<div v-highlight="highlightColor">这是一个高亮的 div</div>'
});

5. unbind 钩子函数

  • 作用unbind 钩子函数会在指令与元素解绑时调用,而且只调用一次。这时候你可以做一些清理工作,比如移除事件监听器。
  • 使用场景:当你需要在指令与元素解绑时做一些清理工作,就可以用 unbind 钩子函数。
// 自定义一个名为 'click-outside' 的指令
Vue.directive('click-outside', {// bind 钩子函数,在指令第一次绑定到元素时调用bind: function (el, binding, vnode) {// 定义一个点击事件处理函数el.clickOutsideEvent = function (event) {// 判断点击事件是否发生在元素外部if (!(el === event.target || el.contains(event.target))) {// 如果点击事件发生在元素外部,调用指令绑定的方法vnode.context[binding.expression](event);}};// 给 document 添加点击事件监听器document.addEventListener('click', el.clickOutsideEvent);},// unbind 钩子函数,在指令与元素解绑时调用unbind: function (el) {// 移除 document 上的点击事件监听器document.removeEventListener('click', el.clickOutsideEvent);// 删除元素上的点击事件处理函数delete el.clickOutsideEvent;// 打印一条消息,提示指令已与元素解绑console.log('指令已与元素解绑');}
});// 创建一个 Vue 实例
new Vue({el: '#app',methods: {// 定义一个方法,用于处理点击元素外部的事件handleClickOutside: function () {console.log('点击了元素外部');}},template: '<div v-click-outside="handleClickOutside">点击这个 div 外部试试</div>'
});

这些钩子函数能让你在不同的阶段对指令绑定的元素进行操作,大大增强了 Vue 指令的灵活性。你可以根据具体的需求选择合适的钩子函数来使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42192.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

知识就是力量——物联网应用技术

基础知识篇 一、常用电子元器件1——USB Type C 接口引脚详解特点接口定义作用主从设备关于6P引脚的简介 2——常用通信芯片CH343P概述特点引脚定义 CH340概述特点封装 3——蜂鸣器概述类型驱动电路原文链接 二、常用封装介绍贴片电阻电容封装介绍封装尺寸与功率关系&#xff1…

.Net SSO 单点登录方式

SSO单点登录目的 之前一般来讲系统简单&#xff0c;登录后 本地 cookie 加服务器 session 存储用户身份信息&#xff0c;以此为依据来判断用户再次登录时免验证 但随着互联网发展&#xff0c;很多应用 部署在不同的服务器上&#xff0c;而用户体系是一套&#xff0c;那么按照原…

MyBatis-Flex、MyBatis-Plus 与 Fluent-Mybatis 的比较分析

MyBatis-Flex、MyBatis-Plus 与 Fluent-Mybatis 的比较分析 在日常开发中&#xff0c;很多项目会选择 MyBatis 作为 ORM&#xff08;对象关系映射&#xff09;框架&#xff0c;而为了减少样板代码和提升开发效率&#xff0c;各种扩展库层出不穷。其中&#xff0c;MyBatis-Flex…

LVS NAT模式实现三台RS的轮询访问

节点规划: 配置RS&#xff1a; RS1-RS3的网关配置均为 192.168.163.8 配置RS1&#xff1a; [rootlocalhost ~]# hostnamectl hostname rs1 [rootlocalhost ~]# nmcli c modify ens160 ipv4.method manual ipv4.addresses 192.168.163.7/24 ipv4.gateway 192.168.163.8 conne…

软考中级-软件设计师 23种设计模式(内含详细解析)

23种设计模式 &#x1f3af; 创建型设计模式&#x1f4cc; 抽象工厂&#xff08;Abstract Factory&#xff09; 设计模式&#x1f4cc; 工厂方法&#xff08;Factory Method&#xff09;设计模式&#x1f4cc; 单例&#xff08;Singleton&#xff09;设计模式&#x1f4cc; 生成…

子数组 之 logTrick算法,求解或,与,LCM,GCD

文章目录 gcd的问题最大公约数 求解子数组的&,|,lcm,gcd的最值or计数问题&#xff0c;如果采用暴力的做法&#xff0c;那么时间复杂度会来到o(n^2),其实在求解的过程中&#xff0c;会出现很多的结果不变的情况&#xff0c;所以我们就可以提前结束 存在一定的单调性&#x…

密码学——知识问答

目录 1、阐述公开密钥算法的定义&#xff0c;结合RSA算法说明公钥密码的基本要求。 说明公钥与私钥两种密码学并举例与其应用 1. 公钥密码学&#xff08;非对称加密&#xff09;&#xff1a; 2. 私钥密码学&#xff08;对称加密&#xff09;&#xff1a; 对比公钥与私钥密码…

MySQL 表连接(内连接与外连接)

&#x1f3dd;️专栏&#xff1a;Mysql_猫咪-9527的博客-CSDN博客 &#x1f305;主页&#xff1a;猫咪-9527-CSDN博客 “欲穷千里目&#xff0c;更上一层楼。会当凌绝顶&#xff0c;一览众山小。” 目录 1、表连接的核心概念 1.1 为什么需要表连接&#xff1f; 2、内连接&a…

CI/CD(六) helm部署ingress-nginx(阿里云)

零、修改iptable为ipvs&#xff08;可选&#xff09; 修改 kube-proxy 配置&#xff1a; kubectl edit cm kube-proxy -n kube-system # 将 mode 字段改为 "ipvs" 重启 kube-proxy&#xff1a; kubectl delete pod -l k8s-appkube-proxy -n kube-system 验证 IPVS …

Git 之配置ssh

1、打开 Git Bash 终端 2、设置用户名 git config --global user.name tom3、生成公钥 ssh-keygen -t rsa4、查看公钥 cat ~/.ssh/id_rsa.pub5、将查看到的公钥添加到不同Git平台 6、验证ssh远程连接git仓库 ssh -T gitgitee.com ssh -T gitcodeup.aliyun.com

为Windows10的WSL Ubuntu启动sshd服务并使用Trae远程连接

Windows10的WSL Ubuntu&#xff0c;使用起来非常方便&#xff0c;但是美中不足的是&#xff0c;无法从Windows主机ssh到Ubuntu 。 解决的方法是在Ubuntu安装sshd服务 Ubuntu安装sshd服务 执行命令 sudo apt install openssh-server 安装好后&#xff0c;先本地测试&#x…

unity一个图片的物体,会有透明的效果

如图 想要去掉这个透明效果 选择一个高层级的layer即可。

Windows安装Jenkins配置Allure踩坑,必须单独配置当前windows系统为新的node节点,才可在工具位置中指定节点服务器allure的位置

背景 我为了图省事&#xff0c;在Windows上安装运行Jenkins&#xff0c;通过配置gitee插件拉取代码部署接口自动化项目&#xff0c;配置构建后运行Allure报告&#xff0c;结果报错&#xff1a;找不到Allure和生成的数据。 Allure报错信息 ERROR: Step ‘Allure Report’ abort…

MAC terminal

MAC terminal 苹果打开命令行 command 空格键 terminal

VScode-i18n-ally-Vue

参考这篇文章&#xff0c;做Vue项目的国际化配置&#xff0c;本篇文章主要解释&#xff0c;下载了i18n之后&#xff0c;该如何对Vscode进行配置 https://juejin.cn/post/7271964525998309428 i18n Ally全局配置项 Vscode中安装i18n Ally插件&#xff0c;并设置其配置项&#…

xdoj回忆练

今天是我入职阿里第四个年头&#xff0c;忆往昔&#xff0c;上一篇博客还是自己刚毕业在准备秋招面试的时候&#xff0c;真不得不感慨时间的飞逝。 偶然间打开了xdoj&#xff0c;发现当年自己为造福学弟学妹而创办的新生赛&#xff0c;在两年前已经被学弟学妹们关停了&#xf…

面试八股文--框架篇(SSM)

一、Spring框架 1、什么是spring Spring框架是一个开源的Java平台应用程序框架&#xff0c;由Rod Johnson于2003年首次发布。它提供了一种全面的编程和配置模型&#xff0c;用于构建现代化的基于Java的企业应用程序。Spring框架的核心特性包括依赖注入&#xff08;DI&#xf…

【SQL Server数据库备份详细教程】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

nVisual对接企业微信实现机房设备与连接变更的自动化审批

企业微信的审批可以根据企业实际业务流程创建自动化的审批流&#xff0c;nVisual可以进行机房设备与线缆的可视化规划设计&#xff0c;结合企业微信与nVisual实现机房设备与线缆变更的自动审批&#xff0c;可以显著提高机房运维变更效率与规范性。 一、业务流程 1、业务流程 …

【PCB工艺】时序图(Timing Diagram)

时序图&#xff08;Timing Diagram&#xff09;是描述数字电路信号随时间变化的图示&#xff0c;广泛用于分析和设计时序逻辑电路&#xff0c;如锁存器&#xff08;Latch&#xff09;、触发器&#xff08;Flip-Flop&#xff09;、计数器、状态机等。这篇文章从时序图的原理、构…