新建文件src\permisstion.ts
main.ts引入
![image.png](https://img-blog.csdnimg.cn/img_convert/68a80984074851998f92b0bdf46433ba.png)
安装进度条插件 npm i nprogress
import router from '@/router'
import nprogress from 'nprogress'
import 'nprogress/nprogress.css'
router.beforeEach((to: any, from: any, next: any) => {
nprogress.start()
next()
})
router.afterEach((to: any, from: any) => {
nprogress.done()
})
## permisstion.ts 路由鉴权:项目当中路由能不能被访问的权限
import router from '@/router'
import setting from './setting'
import nprogress from 'nprogress'
import 'nprogress/nprogress.css'
nprogress.configure({ showSpinner: false })
import useUserStore from './store/modules/user'
import pinia from './store'
const userStore = useUserStore(pinia)
router.beforeEach(async (to: any, from: any, next: any) => {
document.title = `${setting.title}-${to.meta.title}`
nprogress.start()
const token = userStore.token
let username = userStore.username
if (token) {
if (to.path == '/login') {
next('/home')
} else {
if (username) {
next()
} else {
try {
await userStore.userInfo()
next()
} catch (error) {
userStore.userLogout()
next({ path: '/login', query: { redirect: to.path } })
}
}
}
} else {
if (to.path == '/login') {
next()
} else {
next({ path: '/login', query: { redirect: to.path } })
}
}
next()
})
router.afterEach((to: any, from: any) => {
nprogress.done()
})
这里获取用户小仓库为什么要导入pinia
![image.png](https://img-blog.csdnimg.cn/img_convert/a6bf100ac785ffe6bac675bbb2f10e63.png)
- 之前在app中是不需要导入pinia的,是因为我们这次的文件时写在和main.ts同级的下面,所以我们使用的时候是没有pinia的。
若依的permission.js文件
import router from './router'
import store from './store'
import { Message } from 'element-ui'
import NProgress from 'nprogress'
import 'nprogress/nprogress.css'
import { getToken } from '@/utils/auth'
import { isRelogin } from '@/utils/request'
NProgress.configure({ showSpinner: false })
const whiteList = ['/login', '/auth-redirect', '/bind', '/register']
router.beforeEach((to, from, next) => {
NProgress.start()
if (getToken()) {
to.meta.title && store.dispatch('settings/setTitle', to.meta.title)
if (to.path === '/login') {
next({ path: '/' })
NProgress.done()
} else {
if (store.getters.roles.length === 0) {
isRelogin.show = true
store.dispatch('GetInfo').then(() => {
isRelogin.show = false
store.dispatch('GenerateRoutes').then(accessRoutes => {
router.addRoutes(accessRoutes)
next({ ...to, replace: true })
})
}).catch(err => {
store.dispatch('LogOut').then(() => {
Message.error(err)
next({ path: '/' })
})
})
} else {
next()
}
}
} else {
if (whiteList.indexOf(to.path) !== -1) {
next()
} else {
next(`/login?redirect=${to.fullPath}`)
NProgress.done()
}
}
})
router.afterEach(() => {
NProgress.done()
})