vue自定义加载指令最新详解
前言
用过element-ui
的都应该知道,里面有一个loading
组件,有两种调用方法:指令和服务。但是只有一种加载效果,为了丰富加载效果和方便使用,于是写了一个自定义loading
指令。
创建加载组件
首先,需要创建loading
组件,展示需要的加载效果,因人而异,不再赘述。
创建指令
指令文件
首先,创建一个js
文件用于书写自定义指令,在这个文件中导入Vue
和loading
组件:
import Vue from 'vue' import loading from './loading.vue'
创建构造器
主要是使用Vue.extend
构造器,可以简单的理解为传入一个组件作为参数,然后返回该组件的类,可以使用这个类new
出实例。
// loading组件作为参数传入 const loadingConstructor = Vue.extend(loading)
书写指令
在此之前,设定好指令的参数,在本人的项目中,参数有两种方式:1.传入一个布尔值,代表是否开启加载;2.传入一个对象,对象中包含是否开启遮罩、提示文字、加载背景颜色等属性,方便开发时,高度自定义laoding
。
指令的触发主要是在update
中,该属性可接收一个函数,每次指令的参数改变时都会触发该函数,就是在这里判断开启或者关闭加载效果。 整体代码如下,附有详细注释:
const loadingDirective = Vue => { Vue.directive('custLoading', { /** * binding: * 1.可传单个参数,为布尔值; * 2.也可用json传多个参数{ loading, tip, background } * 2.1 loading { boolean } 是否开启遮罩 * 2.2 tip { string } 提示文字 * 2.3 background { string } 加载背景颜色 * */ // update: 参数变化时触发 update: function (el, binding, vnode) { const value = binding.value let backup = {} // 判断参数类型,将参数都转换为对象,方便后续统一处理 typeof value === 'boolean' ? (backup.loading = value) : (backup = value || {}) // 取出所有的参数 const { loading, tip, background } = backup // 根据loading参数判断开启或者关闭加载效果,开启和关闭函数后续会讲到 loading ? createLoading(el, tip, background) : close(el?.customLoadingInstance?.$el) }, // unbid: 指令卸载时触发 unbind: function (el, binding) { const { loading } = binding.value || {} // 如果还在展示加载特效,则关闭 loading && close(el?.customLoadingInstance?.$el) } }) } export default loadingDirective
开启函数
在上面的指令中,当开启的参数为true
时,回会调用一个createLoading
函数用于将加载效果加入到指令挂载的元素上,具体思路如下:1.
在调用时,我们传入了三个参数给它,分别是挂载有自定义加载指令的元素、加载时的提示、加载背景颜色,详细可见上面的指令代码。2.
在执行之前,还需要进行判断当前的Vue
实例是否运行在服务器上,如果是,此时不需要将加载效果展示出来;或者该元素之前是否已经带有加载特效,如果是的话,没必要在开启一次,不然到时会出现多层加载效果,既多余,又让页面显得混乱。3.
判断需要使用加载效果的元素是否还存在,不存在,则挂载到#main
或者document.body
上。4.
判断元素上是否存在定位或者其他条件,在本人的项目中,使用绝对定位来使加载效果铺满元素,因此需要进行判断,如果没有定位,则加上relative
。5.
使用loadingConstructor
,创建loading
实例,将实例作为子元素通过appendChild
,放进需要展示的元素中,就可以展示出来;同时,在展示的元素上增加一个属性customLoadingInstance
,用于记录当前的loading
实例,方便后续的销毁。
整体代码如下:
const createLoading = (target, tip= '加载中,请稍候...', background) => { // 判断是否允许开启加载特效 if (Vue.prototype.$isServer || target?.customLoadingInstance) return const mainEL = document.querySelector('#main') // 判断展示加载效果的元素是否存在 const parentNode = target || mainEL || document.body // 判断父级是否存在定位,没有则添加定位 const position = getComputedStyle(parentNode)?.position (!position || position === 'static') && (parentNode.style.position = 'relative') // 创建loading实例 const instance = new loadingConstructor({ el: document.createElement('div'), data: { background, tip, parentNodeWidth: parentNode.clientWidth, isShow: true } }) // 注意:loading实例是一个Vue组件对象,真正的DOM放在实例的$el属性上 parentNode.appendChild(instance.$el) parentNode.customLoadingInstance = instance return instance }
关闭函数
有开启就得有结束,当开启的参数为false
时,关闭加载效果。该函数接收loading
实例的$el
,其实就是加载效果的DOM
元素,思路如下:1.
为了使加载组件看起来是逐渐消失的,不得在第一时间将加载效果的DOM
元素删除,而是给它添加一个逐渐消失的动画,通过一个class
设定。2.
设定动画消失时间,由loading
组件内部实现在规定时间内,将整个加载效果执行完成或者淡出页面。也可省略此步骤,直接就将其移除。 之所以加入这个效果,是为了用户视觉上感受更好。3.
创建定时器,用于在加载效果消失时,删除加载效果的DOM
元素。同2,也可直接移除。
const close = (target) => { if (!target) return // 添加逐渐消失的class target.className += ' custom-loading-disappear' // 获取loading实例 const instance = target?.parentNode?.customLoadingInstance // 设定消失时间。 instance?.$data?.dur && (instance.$data.dur = 0.8) // 设定定时器,用于在加载效果消失时,删除加载效果的`DOM`元素。 let timer = setTimeout(() => { if (target && target.parentNode) { // 将customLoadingInstance 属性置为null,才不会干扰下一次开启 target.parentNode.customLoadingInstance = null // 将加载效果的DOM元素移除 target.parentNode.removeChild(target) } clearTimeout(timer) timer = null }, 1100) }
到此这篇关于vue自定义加载指令的文章就介绍到这了,更多相关vue自定义加载指令内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue使用elementui的el-menu的折叠菜单collapse示例详解
这篇文章主要介绍了vue使用elementui的el-menu的折叠菜单collapse示例详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-12-12vue中使用echarts刷新可以正常渲染但路由跳转不显示的问题解决
在 Vue 中使用 ECharts 组件时,遇到路由跳转后图表不显示的问题可能是因为组件销毁和重新创建的原因,所以本文给大家介绍了vue中使用echarts刷新可以正常渲染但路由跳转不显示问题的解决方法,需要的朋友可以参考下2024-02-02el-form-item prop属性动态绑定不生效问题及解决
这篇文章主要介绍了el-form-item prop属性动态绑定不生效问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-07-07electron-vue 项目添加启动loading动画的实现思路
electron-vue脚手架搭建的项目,在开发阶段可能你注意不到项目启动慢的问题,但是在build 生成的exe可执行文件,启动后,要反应很久才能进入到app.vue 中加载的页面,体验性很差,本文给大家介绍electron vue启动动画效果的实例代码,感兴趣的朋友一起看看吧2022-01-01vue+tsc+noEmit导致打包报TS类型错误问题及解决方法
当我们新建vue3项目,package.json文件会自动给我添加一些配置选项,这写选项基本没有问题,但是在实际操作过程中,当项目越来越复杂就会出现问题,本文给大家分享vue+tsc+noEmit导致打包报TS类型错误问题及解决方法,感兴趣的朋友一起看看吧2023-10-10
最新评论