vue页面加载时的进度条功能(实例代码)


Posted in Javascript onJanuary 13, 2020

先看一张图

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 引入的话,如下

<script src='nprogress.js'></script>
<link rel='stylesheet' href='nprogress.css'/>

设置进度条颜色

如果是一般的 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: "<div class='....'>...</div>"
});

// 举例
NProgress.configure({
 template: "<div class='other-instance'><div role='bar'>更改标记</div></div>"
})

使用 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页面加载时的进度条功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
基于JQuery的访问WebService的代码(可访问Java[Xfire])
Nov 19 Javascript
让innerText在firefox火狐和IE浏览器都能用的写法
May 14 Javascript
关于javascript event flow 的一个bug详解
Sep 17 Javascript
js日期对象兼容性的处理方法
Jan 28 Javascript
jQuery的3种请求方式$.post,$.get,$.getJSON
Mar 28 Javascript
元素未显示设置width/height时IE中使用currentStyle获取为auto
May 04 Javascript
Angular中$compile源码分析
Jan 28 Javascript
JS动态插入并立即执行回调函数的方法
Apr 21 Javascript
让浏览器崩溃的12行JS代码(DoS攻击分析及防御)
Oct 10 Javascript
bootstrapValidator表单验证插件学习
Dec 30 Javascript
详解VueJS 数据驱动和依赖追踪分析
Jul 26 Javascript
vue中路由验证和相应拦截的使用详解
Dec 13 Javascript
微信小程序canvas截取任意形状的实现代码
Jan 13 #Javascript
js实现列表向上无限滚动
Jan 13 #Javascript
vue 组件销毁并重置的实现
Jan 13 #Javascript
VUE实现自身整体组件销毁的示例代码
Jan 13 #Javascript
微信小程序聊天功能的示例代码
Jan 13 #Javascript
js实现适配移动端的拖动效果
Jan 13 #Javascript
Vue 嵌套路由使用总结(推荐)
Jan 13 #Javascript
You might like
PHP静态延迟绑定和普通静态效率的对比
2017/10/20 PHP
javascript当onmousedown、onmouseup、onclick同时应用于同一个标签节点Element
2010/01/05 Javascript
Extjs中DisplayField的日期或者数字格式化扩展
2010/09/03 Javascript
JavaScript ( (__ = !$ + $)[+$] + ({} + $)[_/_] +({} + $)[_/_] )
2011/02/25 Javascript
关于jQuery中.attr()和.prop()的问题探讨
2013/09/06 Javascript
Javascript脚本实现静态网页加密实例代码
2013/11/05 Javascript
微信小程序 获取设备信息 API实例详解
2016/10/02 Javascript
js插件Jcrop自定义截取图片功能
2016/10/14 Javascript
ionic进入多级目录后隐藏底部导航栏(tabs)的完美解决方案
2016/11/23 Javascript
Angular实现购物车计算示例代码
2017/02/21 Javascript
JavaScript数组去重的多种方法(四种)
2017/09/19 Javascript
小程序实现单选多选功能
2018/11/04 Javascript
详解key在Vue列表渲染时究竟起到了什么作用
2019/04/20 Javascript
JavaScript中的惰性载入函数及优势
2020/02/18 Javascript
简单了解前端渐进式框架VUE
2020/07/20 Javascript
手写Vue2.0 数据劫持的示例
2021/03/04 Vue.js
[59:44]2018DOTA2亚洲邀请赛 3.31 小组赛 B组 paiN vs iG
2018/03/31 DOTA
Python urlopen()函数 示例分享
2014/06/12 Python
浅析Python多线程下的变量问题
2015/04/28 Python
Python信息抽取之乱码解决办法
2017/06/29 Python
python3实现跳一跳点击跳跃
2018/01/08 Python
详解Django中六个常用的自定义装饰器
2018/07/04 Python
Python读取YUV文件,并显示的方法
2018/12/04 Python
解决pycharm工程启动卡住没反应的问题
2019/01/19 Python
Python实现在Windows平台修改文件属性
2020/03/05 Python
简单总结CSS3中视窗单位Viewport的常见用法
2016/02/04 HTML / CSS
自我评价的范文
2014/02/02 职场文书
田径运动会开幕式及主持词
2014/03/28 职场文书
政府门卫岗位职责
2014/04/29 职场文书
校庆标语集锦
2014/06/25 职场文书
作风大整顿心得体会
2014/09/10 职场文书
法人授权委托书样本
2014/09/19 职场文书
教研活动主持词
2015/07/03 职场文书
2016年学校“6﹒26国际禁毒日”宣传活动总结
2016/04/05 职场文书
人事部:年度述职报告范文
2019/07/12 职场文书
不知如何爱孩子,这些方法教会您
2019/08/06 职场文书