vue自定义封装指令及实际使用的方法
导读:本文共4356字符,通常情况下阅读需要15分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要: 前言vue默认内置了v-model、v-if、v-show、v-html、v-text等指令,但是这些往往不足以满足我们实际项目开发中的场景,比如权限控制按钮、路由菜单,复制文字等功能,就需要我们自己自定义一些满足我们项目需求的指令了,那怎么封装自定义指令,并使用呢?我们先从封装指令的基础说起。封装指令基础钩子函数bind:只调用一次,指令第一次绑定到元素时调用... ...
目录
(为您整理了一些要点),点击可以直达。vue默认内置了v-model、v-if、v-show、v-html、v-text等指令,但是这些往往不足以满足我们实际项目开发中的场景,比如权限控制按钮、路由菜单,复制文字等功能,就需要我们自己自定义一些满足我们项目需求的指令了,那怎么封装自定义指令,并使用呢?我们先从封装指令的基础说起。
bind:只调用一次,指令第一次绑定到元素时调用。可以进行一次性初始化设置。
inserted:被绑定元素插入父节点时调用(仅保证父节点存在,但不一定已经被插入文档中)。
update:所在组件的VNode更新时调用,也可能发生在其子VNode更新之前。
componentUpdated:指令所在组件的VNode及其子VNode全部更新后调用。
unbind:只调用一次,指令与元素解绑时调用。
钩子函数参数包含了el、binding、vnode、oldVnode。
el:指令所绑定的元素,可以用来直接操作DOM。
binding:一个对象,包含以下属性
name:指令名。不包括v-前缀(如:v-copy的name为copy)。
value:指令的绑定值(如:v-copy='1 + 1'中,value值为2)。
oldValue:指令绑定的前一个值,仅在update和componentUpdated钩子函数中可用,无论值是否改变都可用。
expression:字符串形式的指令表达式(如:v-copy='1 + 1',表达式为"1 + 1")。
arg:传给指令的参数(如:v-copy:dblclick中,arg的值为dblclick)。
modifiers:一个包含修饰符的对象(如:v-copy.dblclick.icon中,修饰符对象为:{dblclick: true, icon: true})。
vnode:Vue编译生成的虚拟节点。
oldVnode:上一个虚拟节点。仅在update和componentUpdated钩子函数中可用。
我们先看如何使用:
给el添加点击事件,判断binding的value值是否为空,若为空,默认获取绑定元素的文本内容
给el添加双击事件,判断binding的value值是否为空,若为空,默认获取绑定元素的文本内容
判断el是否已经增加了icon,没有则增加i标签,放置icon,给icon增加点击事件,进行复制
判断是否有id为copyTarget的输入框,没有则创造一个id为copyTarget的输入框,然后进行选中,调用execCommand('copy')进行选中文字的复制。
使用:<el-button v-hasPermi="['activity:school:add']">新增活动</el-button>
从store获取用户的权限数组,判断此时binding的value值是否存在权限数组中,没有则进行按钮的隐藏。
完整代码
vue自定义封装指令及实际使用的方法的详细内容,希望对您有所帮助,信息来源于网络。