网站首页 > 技术文章 正文
Github Star: 26k[1] 官网[2]
NProgress 是什么?
NProgress.js 是一个轻量级的 JavaScript 库,用于在应用的页面顶部显示一个进度条,指示页面加载或异步操作的进度。它非常适合用于单页面应用程序(SPA),能够在路由变化时给用户友好的加载提示。本文是 NProgress.js 的基本使用方法和一些配置选项的详细介绍。
快速开始
安装和引入
NProgress.js 支持管理工具 npm 或 yarn 安装,也支持 CDN 引入。
npm install nprogress -S
#
yarn add nprogress
引入时,别忘了引入 nprogress.css 样式文件
启动和结束进度条
NProgress.start(); // 启动进度条
NProgress.done(); // 结束进度条
设置进度
NProgress.set(0.4); // 设置进度至 40%
设置进度百分比,参数取值 0 ~ 1 之间。如果传 0 类似于调用 .start(),传 1 类似于调用 .done() 方法。
递增进度条
NProgress.inc(); // 随机递增进度条
NProgress.inc(0.2); // 以 0.2 的值递增进度条
递增进度条,以随机量增加,永远不会到达 100%。
配置选项
NProgress.configure({
easing: 'ease', // 动画方式
speed: 500, // 递增进度条的速度
showSpinner: false, // 是否显示加载指示器
trickle: false, // 是否开启自动递增行为
trickleSpeed: 200, // 自动递增间隔
minimum: 0.3, // 更改启动时使用的最小百分比
parent: 'body', // 指定进度条的父容器
barSelector: '[role="bar"]', // 进度条选择器
spinnerSelector: '[role="spinner"]' // 加载指示器选择器
});
配置项还有 template 自定义模板,为了保证正常工作,需要保留一个带 role='bar' 的元素。参考默认模板。
NProgress.configure({
template: `
<div class="bar" role="bar">
<div class="peg"></div>
</div>
<div class="spinner" role="spinner">
<div class="spinner-icon"></div>
</div>`
})
另外,通过覆盖 nprogress.css 样式,可以实现定制化样式。
在 Vue 中使用
在 Vue 项目中,可以将 NProgress.js 集成到路由系统中,方便页面跳转时显示进度条。在 router/index.js 中引入 NProgress 并在路由卫士中调用相应的 API。
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
// 导入进度条
import { start, close } from '../utils/nprogress';
const router = new VueRouter({
// ...
});
router.beforeEach((to, from, next) => {
NProgress.start();
next();
});
router.afterEach(() => {
NProgress.done();
});
修改进度条样式
通过添加 CSS 样式来自定义进度条的颜色和其他视觉效果。
#nprogress .bar {
background: green !important; /* 自定义颜色 */
}
总结
NProgress.js 使用一种简单的方式来改善用户体验,在单页应用中,通过在页面跳转期间显示进度条,可以让用户知道页面正在加载,从而减少用户的等待焦虑感。通过本文相信你已经能够在项目中轻松使用 NProgress.js 了。
祝好!
引用链接
[1] Github Star: 26k: https://github.com/rstacruz/nprogress
[2] 官网: https://ricostacruz.com/nprogress/
猜你喜欢
- 2024-11-17 JavaScript爆款进度条组件—NProgress.js
- 2024-11-17 2021 EHA | 急性髓系白血病治疗方案与预后因素的探索
- 2024-11-17 python txt文件截取数据处理(python如何将txt文件中的字段提取到excel中)
- 2024-11-17 手把手教你发布vue组件到npm(vue怎么发布)
- 2024-11-17 n8n:一个可扩展的工作流程自动化工具
- 2024-11-17 如何解决使用npm安装vue脚手架报错问题?20个常见解决方法汇总!
- 2024-11-17 圆锥曲线:代点法求轨迹方程(代入法求圆的轨迹方程)
- 2024-11-17 ubuntu安装最新的node(ubuntu 安装nodejs npm)
- 2024-11-17 遗传学特征对老年急性髓系白血病患者MRD和移植结局的影响
- 2024-11-17 yarn更换为淘宝镜像(npm改淘宝镜像)
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)