NProgress.js,一款神奇的 JavaScript 开源库——页面进度条

官网

https://ricostacruz.com/nprogress/

NProgress 是什么?

NProgress.js 是一个轻量级的 JavaScript 库,用于在应用的页面顶部显示一个进度条,指示页面加载或异步操作的进度。它非常适合用于单页面应用程序(SPA),能够在路由变化时给用户友好的加载提示。本文是 NProgress.js 的基本使用方法和一些配置选项的详细介绍。

 

快速开始 

安装

NProgress.js 支持管理工具 npm 或 yarn 安装,也支持 CDN 引入。

npm install nprogress -S
#
yarn add nprogress
引入 

引入时,别忘了引入 nprogress.css 样式文件

import NProgress  from 'nprogress'

import 'nprogress/nprogress.css'
启动和结束进度条
NProgress.start(); // 启动进度条
NProgress.done(); // 结束进度条

设置进度

设置进度百分比,参数取值 0 ~ 1 之间。如果传 0 类似于调用 .start(),传 1 类似于调用 .done() 方法

NProgress.set(0.4); // 设置进度至 40%

 递增进度条

递增进度条,以随机量增加,永远不会到达 100%。

NProgress.inc(); // 随机递增进度条
NProgress.inc(0.2); // 以 0.2 的值递增进度条
 配置选项
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 样式,可以实现定制化样式。

修改进度条样式

通过添加 CSS 样式来自定义进度条的颜色和其他视觉效果。

#nprogress .bar {
  background: green !important; /* 自定义颜色 */
}

在 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();
});

总结

NProgress.js 使用一种简单的方式来改善用户体验,在单页应用中,通过在页面跳转期间显示进度条,可以让用户知道页面正在加载,从而减少用户的等待焦虑感。通过本文相信你已经能够在项目中轻松使用 NProgress.js 了。

### 正确导入 NProgress 库和 nprogress.css 文件的方法 要正确导入 `NProgress` 库以及其配套的 CSS 文件,可以通过多种方式实现。以下是具体方法: #### 方法一:通过 npm 或 yarn 安装并导入 如果项目基于模块化构建工具(如 Webpack),可以先安装 `NProgress` 库[^5]。 ```bash npm install --save nprogress // 或者 yarn add nprogress ``` 接着,在项目的 JavaScript 文件中按照以下方式进行导入[^1][^2]: ```javascript import NProgress from 'nprogress'; // 导入 NProgress 模块 import 'nprogress/nprogress.css'; // 引入进度条样式文件 ``` 此方法适用于现代前端框架(如 Vue、React)中的开发环境。 --- #### 方法二:直接使用 CDN 链接 对于无需打包工具的简单场景,可以直接通过 `<script>` 和 `<link>` 标签加载资源[^4]。 在 HTML 文件头部添加以下代码即可完成引入: ```html <!-- 引入 NProgress 的 CSS --> <link rel="stylesheet" href="https://unpkg.com/nprogress@0.2.0/nprogress.css"> <!-- 引入 NProgressJS --> <script src="https://unpkg.com/nprogress@0.2.0/nprogress.js"></script> ``` 这种方式适合静态页面或者快速原型设计。 --- #### 方法三:结合实际使用案例 无论采用上述哪种方式,都需要调用 `NProgress.start()` 开始显示进度条,并通过 `NProgress.done()` 结束动画效果。 例如,在 Axios 请求拦截器中集成进度条功能: ```javascript import axios from 'axios'; import NProgress from 'nprogress'; import 'nprogress/nprogress.css'; // 添加请求拦截器 axios.interceptors.request.use(config => { NProgress.start(); // 启动进度条 return config; }, error => { NProgress.done(); // 错误情况下停止进度条 return Promise.reject(error); }); // 添加响应拦截器 axios.interceptors.response.use(response => { NProgress.done(); // 响应成功后停止进度条 return response; }, error => { NProgress.done(); // 响应错误时停止进度条 return Promise.reject(error); }); ``` 以上代码展示了如何将 `NProgress` 整合到 HTTP 请求流程中。 --- ### 总结 根据需求可以选择不同的引入方式: - 如果项目支持 ES6 模块语法,则推荐 **方法一**; - 对于纯静态网页或不依赖构建工具的情况,建议使用 **方法二**。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值