定义自定义指令;inserted()、update()
自定义指令的意义:对普通DOM元素进行底层操作;
作用 :可以获取到底层的dom,拿到想要的节点,从而进行操作;
实际应用:可以通过指令知道什么时候dom创建完成,从而进行依赖dom的库的初始化工作;
<body><div id="box"><div v-hello>11111</div></div><script>Vue.directive("hello",{//指令的生命周期函数inserted(el){console.log("inserted",el)}})new Vue({el: "#box",data: {}})</script></body>
结果:
代码中:div标签里的 hello 是自定义的指令,在dom中用的时候就是:v-指令;
定义hello指令,通过Vue.directive(“指令名”,{}),和定义组件形式一样;
inserted()生命周期函数:
inserted()生命周期函数:
触发时间:节点第一次插入到父节点(页面)中会触发,只会触发这一次;
用法:inserted(接收dom节点的形参,接收指令参数的形参)
如何拿到底层dom节点呢:
- 通过指令的生命周期函数:inserted(),这个函数的作用是只要当前节点插到页面上,这个函数就会自动执行,就会获取到该节点;
- 注意:inserted是指令的生命周期函数跟组件的生命周期函数没关系,不一样,是相互独立的;
inserted函数的参数el:
- 这个参数就是当前节点,当前节点看你把指令用在谁身上喽。代码中hello指令在子div身上,所以拿到的就是"<div>11111</div>"这个节点;
指令里面也可以传参数:
- 传参数的写法:要加上引号:
<div v-hello=" 'yellow' ">11111</div>//yellow是参数
- 不加引号的,直接写在里面的,传的是状态,不是参数:
<div v-hello="yellow">11111</div>//yellow是状态
inserted接收参数: binding
<div id="box"><div v-hello=" 'yellow' ">11111</div>
</div>
Vue.directive("hello",{//指令的生命周期函数inserted(el,binding){console.log("inserted",binding)el.style.background = binding.value}})
- inserted第二个参数binding是接收“yellow”参数的,结果是对象:
- 结果:
- 对象里面的value值放的就是yellow属性,再把这个属性赋值给标签做样式,就很有用:
el.style.background = binding.value
update():更新时期的生命周期函数
- 如果想更改这个参数,也就是 指令接收的参数:v-hello=" 'yellow' ,会发现不好用,改不了,因为inserted生命周期函数只在节点插入父节点的时候,会自动执行一次,后面就不会再执行了;
- 如果想更改参数,可以用指令的生命周期函数update():
update():更新时期的生命周期函数
触发事件:当指令的参数或者状态有所更新就会触发
用法:update(接收dom节点的形参,接收指令参数的形参)
update(el,binding){console.log("update",binding)el.style.background = binding.value}
完整代码:
<body><div id="box"><div v-hello=" whichcolor ">11111</div></div><script>Vue.directive("hello",{//指令的生命周期函数inserted(el,binding){console.log("inserted",binding)el.style.background = binding.value},update(el,binding){console.log("update",binding)el.style.background = binding.value}})new Vue({el: "#box",data: {whichcolor:'blue'}})</script></body>
结果:
以上两个生命周期函数有简写方式:
Vue.directive("hello",()=>{//每次插入或者更新dom就会操作一次el.style.background = binding.value}),
就是把两个生命周期函数放在一起写;
当然这种简写方式只有不强调单独一个生命周期函数时,可以使用;让只想用单独的inserted函数这样的写法就不好了。
定义自定义指令;inserted()、update()相关推荐
- vue之vue的生命周期、swiper、自定义组件的封装、自定义指令、过滤器、单文件组件及vue-cli
文章目录 1.vue的生命周期 1.1.8个生命周期函数 2.swiper 3.自定义组件的封装 4.自定义指令 4.1.定义 4.2.基本使用 4.3.利用自定义指令传入指定参数修改背景色 5.过滤 ...
- [Vue]自定义指令
前言 系列文章目录: [Vue]目录 老师的课件笔记,不含视频 https://www.aliyundrive.com/s/B8sDe5u56BU 笔记在线版: https://note.youdao ...
- Vue3 学习笔记 —— 破坏式更新、自定义指令 directive
目录 1. 什么叫破坏式更新? 2. Vue3 中的自定义指令 2.1 自定义指令的生命周期 2.1.1 Vue2 Vs Vue3 的自定义指令生命周期 2.1.2 自定义指令的生命周期中,接收的参数 ...
- Vue基础学习笔记Day06_动态组件_插槽_自定义指令
今日目标: 能够了解组件进阶知识 能够掌握自定义指令创建和使用 学习内容: 学习目录: 组件进阶 自定义指令 今日总结 面试题 知识点自测 组件创建, 注册和使用 - 伸手就来特别熟练 指令的作用 1 ...
- 【Vue知识点- No6.】动态组件、插槽、自定义指令、tabbar案例
动态组件.插槽.自定义指令 学习目标 1.能够了解组件进阶知识. 2.能够掌握自定义指令的创建和使用. 3.能够完成tabbar案例的开发. 1.组件进阶 1.0 动态组件 问题:如何切换2个组件,互 ...
- Vue自定义指令——v-focus
前言 本文直接参考vue2.0官方文档, 并演示博主项目中的使用 自定义指令 directive 除了核心功能默认内置的指令 (v-model 和 v-show),Vue 也允许注册自定义指令.注意, ...
- Vue API(directives) 自定义指令
前言:除了vue的内置指令以外,我们可以定义自定义指令.内置指令表相见:https://www.cnblogs.com/ilovexiaoming/p/6840383.html 我们定义一个最简单的 ...
- vue 自定义指令 directive 全局 directives 局部 inserted update
vue 自定义指令 需求 效果 全局 - 自定义指令 代码 局部 - 自定义指令 代码 自定义命令传值 效果 代码 问点 需求 获取标签,扩展额外的功能 效果 全局 - 自定义指令 代码 // mai ...
- vue自定义指令update 和 componentUpdated及bind 和 inserted区别
1. 适用 需要对普通 DOM 元素进行底层操作,这时候就会用到自定义指令 2. 钩子函数参数 除了 el 之外,其它参数都应该是只读的,切勿进行修改 <div v-if="show& ...
最新文章
- 架构师必备技能:教你画出一张合格的技术架构图
- 【计算理论】可判定性 ( 对角线方法 | 证明自然数集 N 与实数集 R 不存在一一对应关系 )
- 2020年高等数学方法与提高(上海理工大学)学习笔记:无穷级数
- 科技行业风投日趋谨慎:VR、机器学习和汽车值得关注
- 泛型java实例_【Java学习笔记】Java6泛型实例
- UVALive 3942 Remember the Word(字典树+DP)
- JAVA面试题(part1)--变量相加与常量相加
- mysql命令行如何建库_MySQL心得2--命令行方式建库和表
- oracle 锁表如何解决_Java高并发解决什么方式
- Linux Bash Shell字符串截取
- 如何消灭 Android 应用中的广告?
- Silverlight安装相关问题
- 【HDU_P3530】Subsequence
- Ubuntu 优化、美化(主题、终端)
- [音频处理]傅里叶变换去噪
- 拿走不谢,最全匹配中国大陆手机号码的正则表达式
- 【Web Design The Missing Link】Handing Error
- Unity_检测颜色相似度
- Web 攻防之业务安全:账号安全案例总结.
- strstr和strchr的区别
热门文章
- R语言倾向性评分:匹配
- websocket系列:基于netty-websocket-spring-boot-starter轻松实现高性能websocket
- MATLAB基础篇——数值分析篇
- 同个网络找不到计算机打印机共享,我已经在一台电脑上设置了打印机共享,为什么另一台电脑输入打印机电脑的IP显示找不到文件...
- Java使用RXTX进行串口SerialPort通讯
- javaweb项目报告(吃货联盟)
- python3生成器函数_Python 3 之 生成器详解
- 如何查看本机所开端口
- Android短信通知亮屏
- Internet的初步了解