网站首页 > 技术文章 正文
vue3中自定义指令的简单案例
官方文档中给了一个很简单的示例,官方文档地址:
https://v3.cn.vuejs.org/guide/custom-directive.html
const app = Vue.createApp({})
// 注册一个全局自定义指令 `v-focus`
app.directive('focus', {
// 当被绑定的元素挂载到 DOM 中时……
mounted(el) {
// 聚焦元素
el.focus()
}
})
然后给了一个使用示例:
<input v-focus />
示例非常简单,按照官方的说明写下这个案例后也能够正常运行。但实际使用肯定不止于此,我们必然会遇到需要传递参数的需求,而且官方文档后面又提到可以给自定义指令传递值和参数,并且给出了一个公式说明:
v-mydirective:[argument]="value"
这里面的argument和value可以通过钩子函数中的binding参数获取到具体就是
binding.value可以获取到自定义指令中的value,binding.arg可以获取到指令的动态参数argument。在这个地方,我犯了一个想当然的错误,举例来说:
<input v-focus[direction]="demo" />
我觉得按照官方文档上的介绍那我应该能得到binding.value是demo,binding.arg是direction,但实际我得到了两个undefined。我以为我应该是传递了两个字符串,这里其实没注意到vue的指令中我这样写实际是传递了一个需要在组件的data中定义的变量。也就是我必须在setup中定义出来这两个变量:
<script setup>
let direction = 'right'
let demo = 'demoStr'
</script>
这样我在自定义指令的钩子函数中就可以得到正确的结果:
app.directive('focus', {
mounted(el, binding){
console.log(binding.value) //这里打印出demoStr
console.log(binding.arg) //这里打印出right
el.focus()
}
})
这里再看上面官方给的公式
v-mydirective:[argument]="value"
这里面的argument和value实际是需要你定义的两个变量,可以接受的值也是可以多种类型的,基本类型或者对象字面量都可以。
<input v-focus[12]="23" /> // binding.value是23,binding.arg是12,数字类型
<input v-focus[true]="false" /> // binding.value是false,binding.arg是true,布尔类型
<input v-focus[direction]="demo" /> //这里binding.value是{valueStr: 'demoStr'}, binding.arg是{direction:'right'}
//setup中定义对象
<script setup>
let direction = {
direction:'right'
}
let demo = {
valueStr: 'demoStr'
}
</script>
//这里也可以使用对象字面量,而不是setup中定义变量
<input v-focus[{direction: 'right'}]="{valueStr: 'demoStr'}" />
自定义指令在组件中使用
比如我们想在elment-plus的组件上使用自定义指令,类似下面这样:
<el-input v-focus:[direction]="pinPadding" ></el-input>
这里的el-input是element-plus提供的组件,它会被渲染成<div>包裹<input>的结构。
这个时候,自定义指令总是会被应用在组件的根节点上,这个时候我们获取input这个节点的方式就会有变化:
app.directive('focus', {
mounted(el, binding){
let subNode = el.getElementsByTagName('input')[0]
subNode.focus()
}
})
同时官方还给出一个注意点:当被应用在一个多根节点的组件上时,指令会被忽略,并且会抛出一个警告。
猜你喜欢
- 2024-10-21 Django 自定义管理命令:从入门到高级
- 2024-10-21 VUE自定义指令 自定义指令的应用场景有哪些?
- 2024-10-21 c4d自定义界面命令——把常用工具摆出来,工作效率大大提高
- 2024-10-21 Vue3.0 如何写自定义指令 vue自定义指令两种方式
- 2024-10-21 Vue学习之自定义指令 vue自定义指令和自定义组件
- 2024-10-21 权限应用-按钮权限标识利用自定义指令控制按钮
- 2024-10-21 关于Angularjs中自定义指令一些有价值的细节和技巧
- 2024-10-21 thinkphp自定义指令 thinkphp自定义错误页面
- 2024-10-21 TCL语言学习笔记(4) -自定义命令(过程/函数)和命名空间
- 2024-10-21 vue-12 自定义指令 vue自定义指令案例
你 发表评论:
欢迎- 11-18软考系统分析师知识点十六:系统实现与测试
- 11-18第16篇 软件工程(四)过程管理与测试管理
- 11-18编程|实例(分书问题)了解数据结构、算法(穷举、递归、回溯)
- 11-18算法-减治法
- 11-18笑疯了!巴基斯坦首金!没有技巧全是蛮力!解说:真远啊!笑死!
- 11-18搜索算法之深度优先、广度优先、约束条件、限界函数及相应算法
- 11-18游戏中的优化指的的是什么?
- 11-18算法-分治法
- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)