最新要闻
- 老头环壶头哥:击败女武神超4千次 期待DLC到来
- 天天资讯:儿子沉迷手机爸爸帮请假“逼”他连玩17小时:效果很好
- 焦点消息!供应iPhone 15的OLED屏幕漏光?国产面板一哥京东方回应:不予评价
- 当前关注:纵享丝滑 回味愉悦:德芙巧克力37.5元/斤(官价5折)
- 每日速看!成龙进组20天把半年的封闭用完了!新电影《龙马精神》4月上映:有吴京参演
- 【天天播资讯】为啥人一上车就爱睡觉?原来是被“催眠”了
- 全球观察:95后大厂女生裸辞开麻将馆当保洁:很享受自由和成就感
- 全球今日报丨2030年前后我国将实施火星采样返回:难度很大
- 【全球播资讯】特斯拉中国2月销量出炉 比亚迪能打5个特斯拉
- 航班晚点 山航机长提速帮乘客5分钟极限转机:提前20分钟到达
- 速递!首钢股份:2月重点产品产量同比均提升 预计国内钢材价格短期震荡偏强
- 世界观天下!我的脑内恋碍选项第二季会出吗_我的脑内恋碍选项第二季
- 【天天报资讯】ChatGPT火出圈!人工智能工程师平均招聘月薪突破2.5万
- 环球热文:三星推出冰淇淋主题键鼠套装:薄荷配色如此清凉
- 集成ChatGPT威力显著:微软Bing日活跃首次破亿
- 每日快报!3月罕见!郑州今日冲上30°C高温:成北方首个30℃+省会级城市
手机
iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- iphone11大小尺寸是多少?苹果iPhone11和iPhone13的区别是什么?
- 警方通报辅警执法直播中被撞飞:犯罪嫌疑人已投案
- 男子被关545天申国赔:获赔18万多 驳回精神抚慰金
- 3天内26名本土感染者,辽宁确诊人数已超安徽
- 广西柳州一男子因纠纷杀害三人后自首
- 洱海坠机4名机组人员被批准为烈士 数千干部群众悼念
家电
记录--Vue自定义指令实现加载中效果v-load(不使用Vue.extend)
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助
网站效果演示:ashuai.work:8888/#/myLoad
(资料图片)
GitHub仓库地址代码:github.com/shuirongshu…
加载中思路分析
实现加载中效果,一般有两种方式:
- 第一种是:搞一个
load组件
,然后使用Vue.extend()方法
去继承一个加载组件去使用,比如笔者的这篇文章:juejin.cn/post/702172… - 第二种是:直接使用指令去在需要加载的
dom
上去创建一个加载中的dom
元素,并指定相应的样式即可。本篇文章说的是第二种。
我们先看一下效果图
v-load效果图
实现步骤一:加上自定义指令
假设我有一个dom元素,我给其加上一个自定义的指令v-load="loading"
,绑定一个具体的布尔值loading
,用于控制开启加载中和关闭加载中
111loading: true.box { width: 160px; height: 80px; border: 2px solid #666;}
接下来,我就要在自定义指令的相关钩子函数中去操作这个dom
元素。
关于自定义指令的入门基础知识可以看官方文档,或者参见笔者之前的关于自定义指令的文章:juejin.cn/post/702960…
实现步骤二:给目标元素创建一个子元素dom用于加载
在自定义指令的初始化bind钩子
函数中,我们可以拿到这个dom
元素,首先给这个目标元素开始相对定位,让用于加载中的子元素dom
去绝对定位,以这个相对定位的父元素进行参考
bind(el, binding) { const target = el; // 父元素相对定位 target.style.position = "relative"; // 子元素遮罩层部分 let loadChild = document.createElement("div"); loadChild.className = "loadClass";}
上述代码中给加载中的子元素loadChild
指定一个样式类名loadClass
在这里小伙伴可能有疑问了,这个自定义指令的样式怎么写呢?自定义指令中也没有style
标签啊?
是的,自定义指令中不能直接写样式,不过没关系,我们可以先写好一个css
样式,然后引入过来使用啊,如下:
// 引入拆分的样式,便于自定义指令中使用import "./index.css"bind(el, binding) { ...... loadChild.className = "loadClass";}
这样的话,className
的样式,可以在引入的同级目录下的./index.css
文件中设置了,loadClass
样式如下:
.loadClass { /* 宽高百分百 */ position: absolute; top: 0; bottom: 0; left: 0; right: 0; /* 默认背景色和颜色 */ background-color: rgba(255, 255, 255, 0.99); color: #0b6ed0; /* 透明度过渡使用搭配display:none; */ opacity: 0.8; transition: all 0.3s; /* 居中 */ display: flex; align-items: center; justify-content: center;}
注意,加载中效果开启和消失,不用使用vue
自带的过渡组件transition
,咱们可以使用透明度
搭配搭配display:none;
去设置
注意,加载中要以父元素为边界去控制,可不能满屏加载哦
然后初始化的时候,看看v-load
绑定的值是true
还是false
,同时加上一个用于隐藏的类名:load-hide
。再把这个加载中的dom
元素追加到目标父元素身上。
loadChild.classList.add("load-hide") // 添加类名target.appendChild(loadChild); // 追加加载中子元素/* 通过透明度实现过渡动画 */.load-hide { opacity: 0;}
这样的话,初始化的加载中就做好了。v-load
绑定的值是false
的时,就隐藏之
实现步骤三:当组件更新时,去添加或移除这个load-hide类名
componentUpdated(el, binding, vnode, oldVnode) { let flag = binding.value let loadChild = el.querySelector(".loadClass") if (flag) { // v-load绑定的值为true,就移除这个类名,就能看到了 loadChild.style.display = "flex" setTimeout(() => { loadChild.classList.remove("load-hide") }, 0); } else { // 绑定的值为false时,再添加这个类名,同时隐藏dom loadChild.classList.add("load-hide") setTimeout(() => { loadChild.style.display = "none" }, 360); } },
注意上述代码中为啥不直接隐藏,而是使用定时器延长360毫秒
再去隐藏,因为笔者设置的加载dom
的过渡时间是0.3秒
,即要等到透明度过渡完了以后,再隐藏加载中dom
,这样看着就自然一些了。
.loadClass { transition: all 0.3s; }
到这里,咱们的v-load
自定义指令的加载中效果,就初步完成了。不过功能有点少,自定义加载中我还想,去动态控制:
- 自定义加载图标名
- 自定义加载文字
- 自定义加载文字颜色
- 自定义加载背景色
那这样怎么办呢?
实现步骤四:优化自定义指令,支持传入更多的参数
此时,我的v-load
自定义指令,就不用绑定一个布尔值了。可以考虑绑定一个对象啊,通过控制这个对象的具体值,来动态控制加载中的效果。
- 原来自定义指令绑定:
v-load = loading
//typeof loading == "boolean"
- 现在自定义指令绑定:
v-load = loading2
//typeof loading2 == "object"
222// 如果想要有更多的配置项,就传一个对象,注意要指定字段loading2: { value: true, icon: "el-icon-eleme", // 自定义加载图标名 text: "客官稍等哦...", // 自定义加载文字 color: "red", // 自定义加载文字颜色 bgColor: "#baf", // 自定义加载背景色}
传参指定相应字段,自定义指令中接参,就要在相关的钩子中去接收并处理这些参数。
如何处理这些参数?
- v-load绑定的值的类型的判断,是布尔值,还是对象,执行不同的操作
- 使用原生js的方式去,创造dom元素、给dom元素指定类名(或添加删除类名)
- 考虑到性能缘故,可以使用文档碎片优化
document.createDocumentFragment()
- 最后丢入遮罩层dom内部即可
完整代码
自定义指令样式文件index.css
.loadClass { /* 宽高百分百 */ position: absolute; top: 0; bottom: 0; left: 0; right: 0; /* 默认背景色和颜色 */ background-color: rgba(255, 255, 255, 0.99); color: #0b6ed0; /* 透明度过渡使用搭配display:none; */ opacity: 0.8; transition: all 0.3s; /* 禁止文字选择 */ user-select: none; display: flex; align-items: center; justify-content: center;}/* 通过透明度实现过渡动画 */.load-hide { opacity: 0;}.loadClass>i { margin-right: 4px;}
自定义指令的js文件index.js
注意,自定义指令还需要注册一下才能使用哦
// 引入拆分的样式,便于自定义指令中使用import "./index.css"export default { // 初始化绑定dom钩子函数 bind(el, binding) { const target = el; // 传参类型判断变量控制 let flag; let isObj; if (typeof binding.value == "boolean") { flag = binding.value isObj = false } if (typeof binding.value == "object") { flag = binding.value.value isObj = true } // 有dom元素才去做操作 if (target) { // 父元素相对定位 target.style.position = "relative"; // 子元素遮罩层部分 let loadChild = document.createElement("div"); loadChild.className = "loadClass"; // 创建文档碎片性能稍微优化一点点 let fragment = document.createDocumentFragment() // 孙子元素1加载图标部分 let iSun = document.createElement("i"); iSun.className = isObj ? binding.value.icon : "el-icon-loading"; // 孙子元素2文字提示部分 let spanSun = document.createElement("span"); spanSun.innerHTML = isObj ? binding.value.text : "加载中..." // 使用文档碎片将iSun和spanSun装起来 fragment.appendChild(iSun); fragment.appendChild(spanSun); // 将文档碎片丢入子元素遮罩层内 loadChild.appendChild(fragment); // 样式判断设置 if (isObj) { loadChild.style.color = binding.value.color loadChild.style.backgroundColor = binding.value.bgColor } // 若为false,就隐藏 if (!flag) { loadChild.classList.add("load-hide") loadChild.style.display = "none" } // 父元素添加子元素遮罩层使用 target.appendChild(loadChild); } }, // dom组件更新操作控制显示和隐藏 componentUpdated(el, binding, vnode, oldVnode) { let flag = typeof binding.value == "boolean" ? binding.value : binding.value.value let loadChild = el.querySelector(".loadClass") if (flag) { loadChild.style.display = "flex" setTimeout(() => { loadChild.classList.remove("load-hide") }, 0); } else { loadChild.classList.add("load-hide") setTimeout(() => { loadChild.style.display = "none" }, 360); } },}
使用自定义load指令的地方
<script>export default { name: "myLoadName", data() { return { // 自定义指令方式,默认绑定的值是布尔值 loading: true, // 如果想要有更多的配置项,就传一个对象,注意要指定字段 loading2: { value: true, icon: "el-icon-eleme", // 自定义加载图标名 text: "客官稍等哦...", // 自定义加载文字 color: "red", // 自定义加载文字颜色 bgColor: "#baf", // 自定义加载背景色 }, tableData: [ { name: "孙悟空", age: 500, home: "花果山水帘洞", like: "桃子", }, { name: "猪八戒", age: 88, home: "高老庄", like: "肉包子", }, { name: "沙和尚", age: 1000, home: "通天河", like: "游泳", }, ], }; }, methods: { loadFn() { this.loading = !this.loading; this.loading2.value = !this.loading2.value; }, },};</script>指令方式加载中...
111
222
本文转载于:
https://juejin.cn/post/7182375025368891429
如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。
关键词:
-
记录--Vue自定义指令实现加载中效果v-load(不使用Vue.extend)
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助网站效果演示:ashuai work:8888 ...
来源: 【世界聚看点】探究SMC局部代码加密技术以及在CTF中的运用
记录--Vue自定义指令实现加载中效果v-load(不使用Vue.extend)
【焦点热闻】十分钟读懂火山引擎 DataLeap 数据治理实践
老头环壶头哥:击败女武神超4千次 期待DLC到来
天天资讯:儿子沉迷手机爸爸帮请假“逼”他连玩17小时:效果很好
焦点消息!供应iPhone 15的OLED屏幕漏光?国产面板一哥京东方回应:不予评价
当前关注:纵享丝滑 回味愉悦:德芙巧克力37.5元/斤(官价5折)
每日速看!成龙进组20天把半年的封闭用完了!新电影《龙马精神》4月上映:有吴京参演
每日视点!通过案例讲解python循环语句
【全球独家】基于应用理解的协议栈优化
关注:串口登录提示"Login incorrect"
热推荐:节能降耗 | AIRIOT智慧电力综合管理解决方案
实时:C++笔记--函数、预处理
【天天播资讯】为啥人一上车就爱睡觉?原来是被“催眠”了
全球观察:95后大厂女生裸辞开麻将馆当保洁:很享受自由和成就感
全球今日报丨2030年前后我国将实施火星采样返回:难度很大
【全球播资讯】特斯拉中国2月销量出炉 比亚迪能打5个特斯拉
航班晚点 山航机长提速帮乘客5分钟极限转机:提前20分钟到达
速递!首钢股份:2月重点产品产量同比均提升 预计国内钢材价格短期震荡偏强
焦点播报:Python常见面试题012. 可迭代对象和迭代器有啥区别?
从5分钟到60秒,袋鼠云数栈在热重启技术上的提效探索之路
世界观天下!我的脑内恋碍选项第二季会出吗_我的脑内恋碍选项第二季
【天天报资讯】ChatGPT火出圈!人工智能工程师平均招聘月薪突破2.5万
环球热文:三星推出冰淇淋主题键鼠套装:薄荷配色如此清凉
集成ChatGPT威力显著:微软Bing日活跃首次破亿
每日快报!3月罕见!郑州今日冲上30°C高温:成北方首个30℃+省会级城市
世界球精选!RTX 50显卡有望使用 GDDR7显存验证方案来了:狂飙36Gbps
无界生态发布会即将举办 焕新后的星纪魅族将带来哪些惊喜?
java代码审计-XSS
全球今日讯!vue中将base64流数据转成pdf文件可打印
环球速讯:1 MySql基础介绍
世界观焦点:英媒:多特蒙德中场贝林厄姆将决定自己的未来
观察:今年五一档已定档10部新片 王一博《长空之王》超65万人想看
天天热讯:海上巨无霸 我国自主研制的全球最大集装箱船今天交付
全球讯息:日本H3火箭首秀失败初步调查结果公布:电源系统异常
重获新“声”!清华开发出可穿戴人工喉咙:还原准确率超90%
天天热点评!美国一邮轮300多人患病呕吐腹泻:疑似感染诺如病毒
React Hooks源码深度解析
当前热文:虹科分享 | B站崩了怎么办?Redis企业版数据库多云战略分析
每日速读!Math.atan2求角度解析
快速打包、发布和管理应用——AppUploader工具介绍
星纪魅族集团宣布成立 全面推行新战略,新理念
热资讯!说唱女歌手转行卖烧烤年入百万 直言:梦想和生活不矛盾
全球观察:索尼α7 IV发布2.00版本固件:增加Creators' App支持
全风化和强风化哪个硬?全风化和强风化的区别是什么?
牛转乾坤是什么意思?牛转乾坤放在家里哪个位置?
离不开你是哪部电视剧主题曲?离不开你的原唱是谁?
惊艳世俗的名字有哪些?惊艳世俗的小说句子有哪些?
卧铺有充电的地方吗?卧铺补票怎么补怎么收费?
每日关注!C++笔记--数组、函数、预处理
索爱mk16i支持通话录音吗?索爱mk16i拍照效果怎么样?
双胡须造型着实罕见!腾势N7申报:首款激光雷达比亚迪来了
网易3A级赛车手游《巅峰极速》今日首测 全球超百款跑车正版授权
汽车和小孩被劫 定位要先续流量费!大众汽车宣布重大决定
讯息:股价涨停 中国上市公司永鼎回应美国室温超导技术:目前不可行
当前看点!财运好的男人手相 什么手相最有财运
IM通讯协议专题学习(六):手把手教你如何在Android上从零使用Protobuf
GO语言学习笔记-方法篇 Study for Go ! Chapter five - Method
每日看点!面试被问到了解哪些开发模型?看这一篇就够了!
热键是什么意思?热键冲突怎么解决?
微信怎么群发消息?微信怎么分组管理好友?
环球微资讯!绝无系统广告!蔚来手机真机曝光:神似索尼
每日看点!比亚迪F品牌越野SUV谍照曝光:对标奔驰大G 价格40万起
每天少睡一两个小时算熬夜?专家提醒:大脑会变笨
A4车主免费变成“A5”车主?奥迪做出重大决定
委员建议在农村淘汰老头乐!推广更好的新能源汽车
qq拍一拍怎么设置?qq拍一拍怎么撤回?
三星n7108d能升级到什么版本?三星N7108D手机参数
springboot~ConditionalOnProperty注解的使用
环球信息:给C#auto属性一个初始值的最佳方法是什么?
当前报道:剑指 Offer 68 - I. 二叉搜索树的最近公共祖先(java解题)
【热闻】在2020年JD Power CSI墨西哥研究中 雪佛兰低于平均水平
每日动态!国内油价仍在上行区间 下一轮预计涨0.07-0.08元/升
每日短讯:世界最长寿女性去世 享年128岁:经历两次世界大战、全球大流行病
焦点速读:回头率爆表!闹市试驾哪吒S:20万级最吸引人的轿跑
报复性消费来了 2023年快递突破200亿件 百亿件仅28天
今日热搜:上大教授蔡传兵:室温超导距离实际应用还很遥远
世界头条:《洋葱》原唱_洋葱歌曲原唱
世界即时看!10Wqps评论中台,如何架构?B站是这么做的!!!
简讯:前端设计模式——中介者模式
全球今日报丨Typora语法
Linux 中如何开启端口
环球微资讯!多地或迎来30℃的“春天”:今夏是否会遭遇极端高温?专家回应
每日热讯!宜家储物柜竟成网红打卡地 上海宜家禁止在仓库拍照
每日消息!农民工大哥火车上用盆炫10袋泡面 饭量让网友惊叹:干活能吃更多
环球观焦点:海尔为何能反超格力
天天快消息!微软坚信Switch可原生运行《使命召唤》:没有理由不能优化
环球快播:Kubernetes 的 HPA 原理详解
世界热资讯!当我把ChatGPT拉进群聊里,我的朋友都玩疯了
NTP校时服务器(时钟服务器)在安防监控系统里的重要性
天天新动态:以宿主机用户身份运行Docker容器
环球讯息:配置中心 | .NET 集成 Nacos 配置中心
3月9日生意社DBP基准价为9475.00元/吨
环球今头条!中核首席专家:人造太阳有望在30年后实现供能 核聚变商用
【天天报资讯】有你在的城市吗?中国“民富”50城:沪京苏杭位列前4 长三角仍是最富庶地区
0.536秒!清华学子拍到中国空间站凌月 画面震撼:网友为中国航天点赞
每日讯息!15年耗费万亿日元 日本国产飞机梦碎:原型机被拆解
【全球新视野】夫妻200万造别墅找陌生人抱团养老 每月1500元 网友并不看好
世界观天下!湖北现购车狂潮 东风系最高降9万遭疯抢 乘联会:其他省份或效仿
全球播报:专家权威点评比亚迪CTB技术:刀片与车身完美结合 只能在比亚迪才能实现