[Vue 配置] Vite + Vue3 项目配置和使用 NProgress

文章归档:https://www.yuque.com/u27599042/coding_star/mfmsrf9tz98ox3qg

安装

bash 复制代码
pnpm i nprogress

配置 NProgress

其他更多可参考,仓库地址:https://github.com/rstacruz/nprogress

在 src/config/nprogress.js 中进行配置

是否展示右上角圆圈加载动画

javascript 复制代码
NProgress.configure({ 
  showSpinner: false
});

设置样式

src/styles/nprogress.css

css 复制代码
#nprogress .bar {
    /* 自定义进度条颜色 */
    background: #fa2c19 !important;
}

#nprogress .peg {
    /* 自定义进度条阴影颜色 */
    box-shadow: 0 0 10px #fa2c19, 0 0 5px #fa2c19 !important;
}

启动时进度的最小百分比

默认 0.08

javascript 复制代码
NProgress.configure({ 
  minimum: 0.1
});

进度条动画和速度

动画可选值:

  • linear:动画从开始到结束保持相同的速度。
  • ease:默认值,动画有一个缓慢的开始,然后加速,在结束之前又变慢。
  • ease-in:动画有一个缓慢的开始。
  • ease-out:动画有一个缓慢的结束。
  • ease-in-out:动画有一个缓慢的开始和一个缓慢的结束。
  • cubic-bezier(n,n,n,n):在三次贝塞尔(cubic-bezier)函数中定义自己的值。可以是从 0 到 1 之间的数字值。
javascript 复制代码
NProgress.configure({ 
  easing: 'ease', 
  speed: 500
});

关闭自动递增

默认 true

javascript 复制代码
NProgress.configure({ 
  trickle: false
});

进度条递增速度

单位毫秒,多久自动递增一次

javascript 复制代码
NProgress.configure({ 
  trickleSpeed: 200
});

指定父容器

默认 body

javascript 复制代码
NProgress.configure({ 
  parent: '#container'
});

引入

在 main.js 中引入 nprogress 配置和样式

javascript 复制代码
import "nprogress/nprogress.css" // nprogress 样式
import "@/styles/nprogress.css" // 自定义修改 nprogress 
import '@/config/nprogress.js' // nprogress 配置

使用

javascript 复制代码
// 在需要使用的地方导入
import NProgress from 'nprogress'

// 开启进度条
NProgress.start()

// 结束进度条
NProgress.done()

// 设置进度条百分比,n 取值 0 - 1
NProgress.set(n)

// 获取进度条状态
NProgress.status()

// 增加进度条进度,但不会到 100%,n 取值 0 - 1
NProgress.inc(n);

vue router 中使用

javascript 复制代码
// 全局前置守卫
router.beforeEach(async(to, from, next) => {
    // 开启进度条
    NProgress.start();
}

// 全局后置守卫
router.afterEach(() => {
    // 结束进度条
    NProgress.done();
});

axios 中使用

javascript 复制代码
//请求拦截器
instance.interceptors.request.use(
    (config) => {
        // 开启进度条
        NProgress.start();
		    //...
    },
    (error) =>{
        // 结束进度条
        NProgress.done();
		    //...
	}
);

//响应拦截器
instance.interceptors.response.use(
    (response) => {
        //响应成功
        // 结束进度条
        NProgress.done();
        //...
    },
    (error) => {
        // 结束进度条
        NProgress.done();
        //...
    }
);
相关推荐
一 乐1 天前
婚纱摄影网站|基于ssm + vue婚纱摄影网站系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·spring boot·后端
Cherry的跨界思维1 天前
28、AI测试环境搭建与全栈工具实战:从本地到云平台的完整指南
java·人工智能·vue3·ai测试·ai全栈·测试全栈·ai测试全栈
C_心欲无痕1 天前
ts - tsconfig.json配置讲解
linux·前端·ubuntu·typescript·json
清沫1 天前
Claude Skills:Agent 能力扩展的新范式
前端·ai编程
yinuo1 天前
前端跨页面通信终极指南:方案拆解、对比分析
前端
北辰alk1 天前
Vue 模板引擎深度解析:基于 HTML 的声明式渲染
vue.js
北辰alk1 天前
Vue 自定义指令完全指南:定义与应用场景详解
vue.js
yinuo1 天前
前端跨页面通讯终极指南⑨:IndexedDB 用法全解析
前端
北辰alk1 天前
Vue 动态路由完全指南:定义与参数获取详解
vue.js
北辰alk1 天前
Vue Router 完全指南:作用与组件详解
vue.js