vue怎么实现页面加载时的进度条功能
这篇文章主要讲解了“vue怎么实现页面加载时的进度条功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue怎么实现页面加载时的进度条功能”吧!
成都创新互联公司是一家集网站建设,万全企业网站建设,万全品牌网站建设,网站定制,万全网站建设报价,网络营销,网络优化,万全网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
先看一张图
如果我们的程序每次页面切换时,顶部也有一个进度条,那会让用户体验提升很大的。
npropgress插件
github地址
简单用法 - Vue 项目为例(详细配置,点击上面的github地址查看文档)
最简单的使用方式:vue项目的每次路由切换时,都加载进度条
安装
npm install --save nprogress
引入
在路由配置文件中引入,写到路由加载前和加载后的两个钩子函数中
// 引入 import NProgress from 'nprogress'; import 'nprogress/nprogress.css'; // 进度条配置项这样写 NProgress.configure({ showSpinner: false }); // 路由跳转前钩子函数中 - 执行进度条开始加载 router.beforeEach((to, from, next) => { NProgress.start(); }); // 路由跳转后钩子函数中 - 执行进度条加载结束 router.afterEach(() => { NProgress.done(); });
如果是 cdn 引入的话,如下
设置进度条颜色
如果是一般的 vue 项目,把样式放到一个css文件中,在项目主文件main.js中引入,下面是 css 样式
#nprogress .bar { background: #00CC00 !important; //自定义颜色 }
配置项
手动控制进度条递增,参数范围是0 - 1,不传参数的话,每次调用都会随机递增,但永远不会到达 100% ,除非调用NProgress.done();
// 调用之前如果进度条的状态 50% NProgress.inc(0.2); // 调用之后 70%
进度条加载完成
带参数true:即使没有调用NProgress.start(),也会显示并执行进度条从 0% - 100% 的状态,然后消失。
不带参数:如果没有调用NProgress.start(),那么此命令不会执行任何操作。
NProgress.done(true);
启动进度条时的最小百分比(默认为 0.08)
NProgress.configure({ minimum: 0.3 });
可以使用模板更改标记。要保持进度条正常工作,要在其中保留一个role='bar'元素,参考默认模板。
// 默认模板 NProgress.configure({ template: "..." }); // 举例 NProgress.configure({ template: "" })更改标记
使用 easing 和 speed 调整动画设置,ease可传递CSS3缓冲动画字符串(如ease、linear、ease-in、ease-out、ease-in-out、cubic-bezier),speed为动画速度(单位ms)。默认分别为 ease 200
NProgress.configure({ easing: 'ease', speed: 200 });
关闭自动递增行为
NProgress.configure({ trickle: false });
调整递增的频率,单位为毫秒
NProgress.configure({ trickleSpeed: 200 });
关闭微调器,默认为开启状态(上图中右上角的那个圆圈加载图标)
NProgress.configure({ showSpinner: false, });
更改父容器
NProgress.configure({ parent:'#container' });
感谢各位的阅读,以上就是“vue怎么实现页面加载时的进度条功能”的内容了,经过本文的学习后,相信大家对vue怎么实现页面加载时的进度条功能这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是创新互联,小编将为大家推送更多相关知识点的文章,欢迎关注!
标题名称:vue怎么实现页面加载时的进度条功能
地址分享:http://myzitong.com/article/gsdpgc.html