1. 概述

老话说的好:能屈能伸的人生,才是完满而丰富的人生。

言归正传,今天我们来聊聊 VUE 中自定义指令的实现。

2. 自定义指令

2.1 文本框聚焦的实现 

<body>
<div id="myDiv"></div>
</body>
<script>
const app = Vue.createApp({
mounted() {
// 文本框聚焦
this.$refs.myInput.focus();
},
template:`
<div>
<input ref="myInput" />
</div>
`
});
const vm = app.mount("#myDiv");

这个例子中,我们用常规的方式实现了文本框的聚焦,下面我们用自定义指令来实现这个功能。

2.2 自定义指令实现文本框聚焦

    const app = Vue.createApp({
template:`
<div>
<input v-myFocus />
</div>
`
}); app.directive('myFocus', {
mounted(element) {
element.focus();
}
})

这里我们使用 app.directive 声明了一个自定义指令 myFocus,在自定义指令中可以使用生命周期函数 mounted()  实现元素的聚焦功能,生命周期函数的参数 element 就是使用指令的元素本身

2.3 局部自定义指令

    const myDirectives = {
myFocus : {
mounted(element) {
element.focus();
}
}
} const app = Vue.createApp({
directives: myDirectives,
template:`
<div>
<input v-myFocus />
</div>
`
});

与局部组件类似,自定义指令也可以局部,在主组件中需要使用 directives 对局部自定义指令进行声明后,才可以使用。

2.4 其他生命周期函数也可以在自定义指令中使用

    const app = Vue.createApp({
template:`
<div>
<input v-myFocus />
</div>
`
}); app.directive('myFocus', {
beforeMount(element) {
console.info('beforeMount');
},
mounted(element) {
console.info('mounted');
element.focus();
},
beforeUpdate(element) {
console.info('beforeUpdate');
},
updated(element) {
console.info('updated');
},
beforeUnmount(element) {
console.info('beforeUnmount');
},
unmounted(element) {
console.info('unmounted');
},
})

2.5 自定义指令传参

    const app = Vue.createApp({
template:`
<div v-pos="100" class="header">
<input />
</div>
`
}); app.directive('pos', {
mounted(element, binding) {
element.style.top = binding.value + 'px';
}
})

在自定义指令的生命周期函数中,再增加一个参数 binding,使用 binding.value 可以拿到自定义指令中传的参数 100

2.6 自定义指令参数绑定数据

    const app = Vue.createApp({
data() {
return {
pos : 200
}
},
template:`
<div v-pos="pos" class="header">
<input />
</div>
`
}); app.directive('pos', {
mounted(element, binding) {
element.style.top = binding.value + 'px';
}
})

此例子,将自定义属性的参数值与数据绑定

2.7 arg 参数的传递

    const app = Vue.createApp({
data() {
return {
pos : 200
}
},
template:`
<div v-pos:top-pos="pos" class="header">
<input />
</div>
`
}); app.directive('pos', {
mounted(element, binding) {
element.style.top = binding.value + 'px';
console.info(binding.arg);
}
})

在使用自定义指令时,可以写成 v-pos:top-pos="pos",自定义指令中可以使用 binding.arg 的方式获得 top-pos 这个值

2.8 arg 参数的使用

    const app = Vue.createApp({
data() {
return {
pos : 200
}
},
template:`
<div v-pos:left-pos="pos" class="header">
<input />
</div>
`
}); app.directive('pos', {
mounted(element, binding) { console.info(binding.arg); if(binding.arg == 'top-pos') {
element.style.top = binding.value + 'px';
} if(binding.arg == 'left-pos') {
element.style.left = binding.value + 'px';
}
}
})

通过对 arg 参数的判断,实现不同的效果。

3. 综述

今天聊了一下 VUE 中自定义指令的实现,希望可以对大家的工作有所帮助,下一节我们继续讲 Vue 中的高级语法,敬请期待

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,这里干货满满,都是实战类技术文章,通俗易懂,轻松上手。

4. 个人公众号

追风人聊Java,欢迎大家关注

VUE3 之 自定义指令的实现 - 这个系列的教程通俗易懂,适合新手的更多相关文章

  1. VUE3 之 render 函数的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 老话说的好:不用想的太多.太远,做好当天的事,知道明天要做什么就可以了. 言归正传,今天我们来聊聊 VUE 中 render 函数的使用. 2. render 函数 2.1 一个简单的例子 ...

  2. 使用 vue3 的自定义指令给 element-plus 的 el-dialog 增加拖拽功能

    element-plus 提供的 el-dialog 对话框功能非常强大,只是美中不足不能通过拖拽的方式改变位置,有点小遗憾,那么怎么办呢?我们可以通过 vue 的自定义指令来实现一个可以拖拽的对话框 ...

  3. vue3.0自定义指令(drectives)

    在大多数情况下,你都可以操作数据来修改视图,或者反之.但是还是避免不了偶尔要操作原生 DOM,这时候,你就能用到自定义指令. 举个例子,你想让页面的文本框自动聚焦,在没有学习自定义指令的时候,我们可能 ...

  4. VUE3 之 多个 v-model 绑定及 v-model 修饰符的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 洛克定律告诉我们: 当我们的目标很远大,远到我们都看不到终点时,放弃几率就会很大,就像跑马拉松比赛,由于时间长.距离长,很多选手都会选择在中途放弃. 其实有个好办法,就是拆分,把大目标拆分 ...

  5. VUE3 之 使用标签实现动画与过渡效果 - 这个系列的教程通俗易懂,适合新手

    1. 概述 巴纳姆效应告诉我们: 人们更容易相信笼统的.常见的人格描述,并觉得特别适合自己,认为该描述真实地反映了自己的人格面貌. 这也是所有算命先生的小把戏,算命先生通常把话说的很笼统,很通用,基本 ...

  6. VUE3 之 使用标签实现动画与过渡效果(下) - 这个系列的教程通俗易懂,适合新手

    1. 概述 毛毛虫效应: 有这样一个实验,将许多毛毛虫放在一个花盆边缘,使它们首尾相接,围成一个圈.然后在离花盆很近的地方撒了一些毛毛虫的食物. 此时,毛毛虫并不会向食物的方向爬去,而是在花盆边缘,一 ...

  7. VUE3 之 插槽的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 非理性定律告诉我们: 人们总是习惯于以情感去判断眼前的事物,非理性的去做决定. 对于长远的利益,人们更愿意去选择短期的利益. 因此在做决定前要让自己冷静,理性的分析,让自己看的更远. 言归 ...

  8. VUE3 之 作用域插槽 - 这个系列的教程通俗易懂,适合新手

    1. 概述 破窗效应告诉我们: 当一个建筑物窗户的玻璃完好无损时,很少有人想去破坏它,当有一个人破坏了一块窗户的玻璃,其他窗户的玻璃也很快会被人破坏. 同理,一个很干净的地方,人们不好意思去丢垃圾,但 ...

  9. VUE3 之 动态组件 - 这个系列的教程通俗易懂,适合新手

    1. 概述 暗示效应告诉我们: 巧妙的暗示会在不知不觉中剥夺我们的判断力,对我们的思维形成一定的影响,造成我们行为的些许改变或者偏差. 例如你的朋友说你脸色不太好,是不是病了,此时,你可能就会感觉浑身 ...

随机推荐

  1. Mybatis 动态 sql 有什么用?执行原理?有哪些动态 sql?

    Mybatis 动态 sql 可以在 Xml 映射文件内,以标签的形式编写动态 sql,执行原理 是根据表达式的值 完成逻辑判断并动态拼接 sql 的功能. Mybatis 提供了 9 种动态 sql ...

  2. Maria DB数据库基础知识

    Maria DB连接 与MariaDB建立连接的一种方法是在命令提示符下使用mysql二进制文件. Maria DB命令行登录数据库服务: mysql -u root -p -- 换行输入密码 上面给 ...

  3. 什么是通知Advice?

    特定 JoinPoint 处的 Aspect 所采取的动作称为 Advice.Spring AOP 使用一个 Advice 作为拦截器,在 JoinPoint "周围"维护一系列的 ...

  4. 学习Kvm(二)

    一.走进云计算 云计算:云计算是一种按使用量付费的模式,这种模式提供可用的.便捷的.按需的网络访问, 进入可配置的计算资源共享池(资源包括网络,服务器,存储,应用软件,服务),这些资源能够被快速提供, ...

  5. 百度移动统计调用api教程,少进坑(82001错误)

    相信很多小伙伴使用了百度统计,来查看自己应用使用的情况,但是会发现百度移动统计在官网没有api调用取数据的接口, 现在我就以自己成功调用api并且成功拿到数据,将这个步骤给大家参考,(末尾有调用移动统 ...

  6. hadoop 分布式系统与Hadoop MapReduce

    Hadoop分为两部分 Hadoop MapReduce和Hadoop分布式文件系统 1分布式系统由Master Node 和多台 slave Node组成. 1.1MasterNode Master ...

  7. python中dtype,type,astype的区别

    python中dtype,type,astype的区别 type() dtype() astype() 函数名称 用法 type 返回参数的数据类型 dtype 返回数组中元素的数据类型 astype ...

  8. ubuntu root密码问题

    安装完Ubuntu后忽然意识到没有设置root密码,不知道密码自然就无法进入根用户下.到网上搜了一下,原来是这麽回事.Ubuntu的默认root密码是随机的,即每次开机都有一个新的root密码.我们可 ...

  9. css盒子模型、垂直外边距合并

    css盒子模型由四部分组成:内容(content).填充(padding).边框(border).边距(margin),其中css样式中定义的width属性是定义内容区域的宽度,正常情况下,设置了内容 ...

  10. Android 接入腾讯IM即时通信(详细图文)

    原文地址:Android 接入腾讯IM即时通信(详细图文) | Stars-One的杂货小窝 腾讯云IM官网文档上提供了带UI模块和不带UI模块的,本文是基于带UI模块进行了Module封装,可以方便 ...