Files
my-bigScreen/screen-vue/src/router/index.js

124 lines
2.5 KiB
JavaScript
Raw Normal View History

2026-03-02 14:33:24 +08:00
import { createRouter, createWebHashHistory } from 'vue-router'
2026-02-24 23:26:41 +08:00
import Login from '@/views/Login.vue'
2026-03-01 21:28:05 +08:00
import Page404 from '@/views/error/404.vue'
import Layout from '@/components/Layout/index.vue'
2026-02-24 23:26:41 +08:00
import Dashboard from '@/views/desktop/index.vue'
2026-03-01 21:28:05 +08:00
import bigScreen from '@/views/screen/index.vue'
const modules = import.meta.glob('../views/**/index.vue', {
eager: false,
import: 'default'
})
const generateRoutes = () => {
const routes = []
Object.entries(modules).forEach(([filePath, module]) => {
const excludePaths = [
'views/Login.vue',
'views/desktop/index.vue',
'views/error/',
'views/screen/',
]
if (excludePaths.some(path => filePath.includes(path))) {
return
}
const routePath = filePath
.replace('../views', '')
.replace('.vue', '')
.toLowerCase()
const routeName = routePath
.split('/')
.filter(Boolean)
.map(seg => seg.charAt(0).toUpperCase() + seg.slice(1))
.join('')
routes.push({
path: routePath,
name: routeName || 'SystemRoleIndex',
component: module
})
})
return routes
}
2026-02-24 23:26:41 +08:00
const routes = [
{
path: '/login',
name: 'Login',
component: Login,
2026-03-01 21:28:05 +08:00
meta: { isPublic: true }
2026-02-24 23:26:41 +08:00
},
{
2026-03-01 21:28:05 +08:00
path: '/bigScreen',
name: 'bigScreen',
component: bigScreen,
meta: { requiresAuth: true }
},
2026-03-02 14:33:24 +08:00
{
path: '/',
redirect: '/login'
},
2026-03-01 21:28:05 +08:00
{
2026-03-02 13:57:22 +08:00
path: '/layout',
2026-03-01 21:28:05 +08:00
component: Layout,
meta: { requiresAuth: true },
children: [
{
2026-03-02 13:57:22 +08:00
path: '/dashboard',
2026-03-01 21:28:05 +08:00
name: 'Dashboard',
component: Dashboard
},
...generateRoutes()
]
2026-02-24 23:26:41 +08:00
},
{
path: '/:pathMatch(.*)*',
2026-03-01 21:28:05 +08:00
name: 'Page404',
component: Page404
2026-02-24 23:26:41 +08:00
}
]
const router = createRouter({
2026-03-02 14:33:24 +08:00
history: createWebHashHistory(import.meta.env.BASE_URL || './'),
2026-02-24 23:26:41 +08:00
routes,
scrollBehavior() {
return { top: 0 }
}
})
2026-03-02 14:33:24 +08:00
// 优化路由守卫适配hash模式增强容错
2026-02-24 23:26:41 +08:00
router.beforeEach((to, from, next) => {
2026-03-02 14:33:24 +08:00
// 1. 公开页面直接放行(登录页)
2026-02-24 23:26:41 +08:00
if (to.meta.isPublic) {
next()
return
}
2026-03-02 14:33:24 +08:00
// 2. 非公开页面校验token兼容hash模式
2026-02-24 23:26:41 +08:00
try {
const token = localStorage.getItem('token')
2026-03-02 14:33:24 +08:00
const isValidToken = token.trim().length > 0
if (isValidToken) {
2026-03-02 13:57:22 +08:00
next()
2026-02-24 23:26:41 +08:00
} else {
2026-03-02 13:57:22 +08:00
next({
path: '/login',
query: { redirect: to.fullPath },
2026-03-02 14:33:24 +08:00
replace: true
2026-03-02 13:57:22 +08:00
})
2026-02-24 23:26:41 +08:00
}
} catch (error) {
2026-03-02 14:33:24 +08:00
console.error('路由守卫校验失败:', error)
next({
path: '/login',
replace: true
})
2026-02-24 23:26:41 +08:00
}
})
export default router