1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- import * as vueRouter from 'vue-router'
- import baseData from './modules/base'
- import { getToken } from '~src/api/auth'
- import { getRouterData } from './routers'
- import NProgress from 'nprogress'
- import '~src/styles/app/nprogress.scss'
- import config from '~src/config/index'
- //设置路由数据
- const router = vueRouter.createRouter({
- history: vueRouter.createWebHashHistory(),
- routes: baseData,
- })
- //路由拦截
- router.beforeResolve(async (to) => {
- NProgress.start()
- const token = getToken(), auth = ['/login']
- if (auth.indexOf(to.path) !== -1) {
- return true
- } else if (!token) {
- return '/login'
- } else {
- const res = await getRouterData(to.name)
- if (res) {
- return true
- } else {
- return '/login'
- }
- }
- })
- router.afterEach((to) => {
- //根据当前跳转的路由设置显示在浏览器标签的title
- let pageTitle = to.meta['title'], title = config.title;
- if (to.path !== "/") {
- window.document.title = pageTitle?`${pageTitle} - ${title}`:title;
- } else {
- window.document.title = title;
- }
- window.scrollTo(0, 0)
- NProgress.done()
- })
- export function setupRouter(app) {
- app.use(router)
- return router
- }
- export default router
|