import type { RouteRecordRaw } from 'vue-router' import type { App } from 'vue' import { createRouter, createWebHashHistory } from 'vue-router' import { basicRoutes } from './routes' // 白名单应该包含基本静态路由 const WHITE_NAME_LIST: string[] = [] const getRouteNames = (array: any[]) => array.forEach((item) => { WHITE_NAME_LIST.push(item.name) getRouteNames(item.children || []) }) getRouteNames(basicRoutes) // app router // 创建一个可以被 Vue 应用程序使用的路由实例 export const router = createRouter({ // 创建一个 hash 历史记录。 history: createWebHashHistory(import.meta.env.VITE_PUBLIC_PATH), // 应该添加到路由的初始路由列表。 routes: basicRoutes as unknown as RouteRecordRaw[], // 是否应该禁止尾部斜杠。默认为假 strict: true, scrollBehavior: () => ({ left: 0, top: 0 }) }) // reset router export function resetRouter() { router.getRoutes().forEach((route) => { const { name } = route if (name && !WHITE_NAME_LIST.includes(name as string)) { router.hasRoute(name) && router.removeRoute(name) } }) } // config router // 配置路由器 export function setupRouter(app: App) { app.use(router) }