【Vue.js 3.0】NProgress 进度条

简介

在 Vue 3 中使用 NProgress,你需要先安装 NProgress,然后在你的 Vue 应用中引入它,并在适当的生命周期钩子或路由守卫中调用它的方法。以下是一个简单的例子来展示如何在 Vue 3 应用中集成 NProgress

首先,你需要安装 NProgress:
复制代码
npm install nprogress

然后,在你的 Vue 3 应用中,你可以在 main.jsmain.ts 文件中引入 NProgress 及其样式,并在路由守卫中使用它。

main.js

复制代码
import { createApp } from 'vue';  
import App from './App.vue';  
import { createRouter, createWebHistory } from 'vue-router';  
import NProgress from 'nprogress';  
import 'nprogress/nprogress.css';  
  
// 假设你已经有了一些路由定义  
const routes = [  
  // ...你的路由配置  
];  
  
const router = createRouter({  
  history: createWebHistory(),  
  routes,  
});  
  
// NProgress 配置、进度环显示隐藏  
NProgress.configure({ showSpinner: false }); 
  
// 路由守卫  
router.beforeEach((to, from, next) => {  
  // 开始进度条  
  NProgress.start();  
  next();  
});  
  
router.afterEach(() => {  
  // 结束进度条  
  NProgress.done();  
});  
  
const app = createApp(App);  
app.use(router);  
app.mount('#app');

下面是一个配置 NProgress 的例子:

复制代码
NProgress.configure({  
  minimum: 0.1,             // 最小百分比  
  speed: 500,               // 动画速度  
  showSpinner: false,      // 不显示微调器  
  trickle: false,          // 关闭自动步进  
  trickleSpeed: 500,       // 自动步进速度(如果trickle为true)  
  ease: 'ease-in-out',     // 动画方式  
  positionUsing: '#custom-container' // 进度条容器选择器  
});	

你可以根据你的需求选择使用哪些配置,并在 configure 方法中设置它们。这样,你就可以定制 NProgress 的行为和外观,使其更好地融入你的 Vue 3 应用中。

相关推荐
一抓掉一大把27 分钟前
MiniExcel模板填充Excel导出
开发语言·javascript·ecmascript
Jiaberrr42 分钟前
uniapp 安卓 APP 后台持续运行(保活)的尝试办法
android·前端·javascript·uni-app·app·保活
不老刘42 分钟前
uniapp+vue3实现CK通信协议(基于jjc-tcpTools)
前端·javascript·uni-app
vanora11111 小时前
Vue在线预览excel、word、ppt等格式数据。
前端·javascript·vue.js
溪饱鱼2 小时前
React源码阅读-fiber核心构建原理
前端·javascript·react.js
xiaogg36782 小时前
网站首页菜单顶部下拉上下布局以及可关闭标签页实现vue+elementui
javascript·vue.js·elementui
胡gh2 小时前
JS面向对象程序设计(OOP)与原型机制,到底是如何一步步走向实用的
javascript
有梦想的攻城狮2 小时前
从0开始学vue:pnpm怎么安装
前端·javascript·vue.js
pzpcxy5202 小时前
安装VUE客户端@vue/cli报错警告npm WARN deprecated解决方法 无法将“vue”项识别为 cmdlet、函数
前端·vue.js·npm
疯狂的沙粒2 小时前
uni-app 如何实现选择和上传非图像、视频文件?
前端·javascript·uni-app