8个非常实用的vue自定义指令

author author     2023-04-24     223

关键词:

参考技术A 在 Vue,除了核心功能默认内置的指令 ( v-model 和 v-show ),Vue 也允许注册自定义指令。它的作用价值在于当开发人员在某些场景下需要对普通 DOM 元素进行操作。

Vue自定义指令有全局注册和局部注册两种方式。先来看看注册全局指令的方式,通过 Vue.directive( id, [definition] ) 方式注册全局指令。然后在入口文件中进行 Vue.use() 调用。

批量注册指令,新建 directives/index.js 文件

在 main.js 引入并调用

指令定义函数提供了几个钩子函数(可选):

下面分享几个实用的 Vue 自定义指令

需求:实现一键复制文本内容,用于鼠标右键粘贴。

思路:

使用:给 Dom 加上 v-copy 及复制的文本即可

需求:实现长按,用户需要按下并按住按钮几秒钟,触发相应的事件

思路:

使用:给 Dom 加上 v-longpress 及回调函数即可

背景:在开发中,有些提交保存按钮有时候会在短时间内被点击多次,这样就会多次重复请求后端接口,造成数据的混乱,比如新增表单的提交按钮,多次点击就会新增多条重复的数据。

需求:防止按钮在短时间内被多次点击,使用防抖函数限制规定时间内只能点击一次。

思路:

使用:给 Dom 加上 v-debounce 及回调函数即可

背景:开发中遇到的表单输入,往往会有对输入内容的限制,比如不能输入表情和特殊字符,只能输入数字或字母等。

我们常规方法是在每一个表单的 on-change 事件上做处理。

这样代码量比较大而且不好维护,所以我们需要自定义一个指令来解决这问题。

需求:根据正则表达式,设计自定义处理表单输入规则的指令,下面以禁止输入表情和特殊字符为例。

使用:将需要校验的输入框加上 v-emoji 即可

背景:在类电商类项目,往往存在大量的图片,如 banner 广告图,菜单导航图,美团等商家列表头图等。图片众多以及图片体积过大往往会影响页面加载速度,造成不良的用户体验,所以进行图片懒加载优化势在必行。

需求:实现一个图片懒加载指令,只加载浏览器可见区域的图片。

思路:

图片懒加载有两种方式可以实现,一是绑定 srcoll 事件进行监听,二是使用 IntersectionObserver 判断图片是否到了可视区域,但是有浏览器兼容性问题。

下面封装一个懒加载指令兼容两种方法,判断浏览器是否支持 IntersectionObserver API,如果支持就使用 IntersectionObserver 实现懒加载,否则则使用 srcoll 事件监听 + 节流的方法实现。

使用,将组件内 标签的 src 换成 v-LazyLoad

背景:在一些后台管理系统,我们可能需要根据用户角色进行一些操作权限的判断,很多时候我们都是粗暴地给一个元素添加 v-if / v-show 来进行显示隐藏,但如果判断条件繁琐且多个地方需要判断,这种方式的代码不仅不优雅而且冗余。针对这种情况,我们可以通过全局自定义指令来处理。

需求:自定义一个权限指令,对需要权限判断的 Dom 进行显示隐藏。

思路:

使用:给 v-permission 赋值判断即可

需求:给整个页面添加背景水印

思路:

使用,设置水印文案,颜色,字体大小即可

需求:实现一个拖拽指令,可在页面可视区域任意拖拽元素。

思路:

使用: 在 Dom 上加上 v-draggable 即可

8个非常实用的vue自定义指令

参考技术A在Vue,除了核心功能默认内置的指令(v-model和v-show),Vue也允许注册自定义指令。它的作用价值在于当开发人员在某些场景下需要对普通DOM元素进行操作。Vue自定义指令有全局注册和局部注册两种方式。先来看看注册全... 查看详情

vue:八种实用的自定义指令(代码片段)

除了核心功能默认内置的指令,Vue也允许注册自定义指令。在Vue2.0中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要对普通DOM元素进行底层操作,这时候就会用到自定义指令。示例:... 查看详情

vue3自定义指令v-copy实现复制文字(代码片段)

...v-copy指令实现Vue3定义全局指令使用一、文章参考分享8个非常实用的Vue自定义指令Vue3自定义指令官方文档二、问题描述工作中有时候会遇到需要实现点击复制的功能,但是不了解实现的原理,只是在网上查找到相关代码&#... 查看详情

vue3自定义指令v-copy实现复制文字(代码片段)

...v-copy指令实现Vue3定义全局指令使用一、文章参考分享8个非常实用的Vue自定义指令Vue3自定义指令官方文档二、问题描述工作中有时候会遇到需要实现点击复制的功能,但是不了解实现的原理,只是在网上查找到相关代码&#... 查看详情

vue3自定义指令v-copy实现复制文字(代码片段)

...v-copy指令实现Vue3定义全局指令使用一、文章参考分享8个非常实用的Vue自定义指令Vue3自定义指令官方文档二、问题描述工作中有时候会遇到需要实现点击复制的功能,但是不了解实现的原理,只是在网上查找到相关代码&#... 查看详情

vue自定义指令

参考技术A自定义指令需要注册后才能使用,Vue提供了两种注册方式:全局注册和局部注册。全局注册使用Vue.directive()方法来注册一个全局自定义指令,该方法接受两个参数,第一个参数是指令的ID(即名字);第二个参数是一个定... 查看详情

vue.js自定义指令的用法与实例

...DOM操作,并且是可复用的。  比如谷歌图片的加载做得非常优雅,在图片未完成加载前 查看详情

angularjs1.x学习笔记8-自定义指令(上)

  AngulaJS的指令是一种非常强大的特性,一个ng-repeat就能让我们非常方便的展示一个数据列表,指令相当于是一个组件,为我们将一些东西封装起来了,提供了复用的可能性。个人认为自定义指令还是比较复杂的,下面开始攻... 查看详情

Vue.js 中的自定义指令

...我使用来自Vuex的mapGetters,但令人惊讶的是,这种方法也非常有效。与其他方法(如在mounted或created挂钩中调用方法)相比,这是否也是正确的或性能方 查看详情

vue自定义指令

...航栏,但是按钮级别当时考虑了两种方案,全局方法和自定义指令。因为考虑到是按钮,没有权限时可直接移除节点,最终采用自定义指令来做。  自定义指令创建完后,全局挂载实际使用:将要比对的 查看详情

vue-自定义指令

...默认内置的指令(v-model 和 v-show),Vue也允许注册自定义指令。注意,在Vue2.0中,代码复用和抽象的主要形式是组件。然而,有的情况下,你仍然需要对普通DOM元素进行底层操作,这时候就会用到自定义指令。举个聚焦输入... 查看详情

vue自定义指令

除了核心功能默认内置的指令(v-model和v-show等),Vue也允许注册自定义指令。1.例子一:<!DOCTYPEhtml><html><headlang="en"><metacharset="UTF-8"><title></title><style></styl 查看详情

vue学习总结笔记(代码片段)

...4.2v-html指令5.v-clock指令6.v-once指令7.v-pre指令8.Vue的自定义指令8.1设置自定义指令的两种方式8.2自定义指令的element参数和binding参数8.3自定义指令对象式8.4全局自定义指令9.Vue的生命周期9.1Vue的生命周期介绍9.2Vue生命周期的整... 查看详情

vue_(组件)自定义指令(代码片段)

    Vue.js自定义指令  传送门    自定义指令:除了内置指令,Vue也允许用户自定义指令  注册指令:通过全局APIVue.directive可以注册自定义指令   自定义指令的钩子函数参数:自定义指令的钩子函... 查看详情

vue.js实现内部自定义指令和全局自定义指令------directive

...,Vue给我们一个很好用的东东directive这个单词是我们写自定义指令的关键字哦之定义指令为我们提供了几个钩子函数,这时候你一定好奇什么是钩子函数,说简单点,就是集中表现状态bind:只调用一次,指令第一次绑定到元素时... 查看详情

vue.js学习item13–指令系统与自定义指令

基础除了内置指令,Vue.js也允许注册自定义指令。自定义指令提供一种机制将数据的变化映射为DOM行为。可以用 Vue.directive(id,definition) 方法注册一个全局自定义指令,它接收两个参数指令ID 与定义对象。也可以用组件... 查看详情

vue基础进阶之自定义指令(代码片段)

自定义指令-----钩子函数自定义指令除了内置指令,Vue也允许用户自定义指令; 注册指令:通过全局APIVue.directive可以注册自定义指令;自定义指令的钩子函数:bind;inserted;update;componentUpdated;unbind;自定义指令的使用:... 查看详情

vue自定义指令使用场景(代码片段)

...致性。如果你需要对HTML进行底层操作的话,这种方式是非常有用的。下面介绍几种指令的使用方式及示例,用example代替了实际的指令。v-example:会实例化一个指令,但这个指令没有参数。如果不传参数会比较不灵活,但是这样就... 查看详情