admin-vben5/apps/web-antd/src/router/index.ts

58 lines
1.7 KiB
TypeScript
Raw Normal View History

2024-05-19 21:20:42 +08:00
import type { RouteRecordName, RouteRecordRaw } from 'vue-router';
import { traverseTreeValues } from '@vben/utils';
2024-05-19 21:20:42 +08:00
import { createRouter, createWebHashHistory } from 'vue-router';
2024-06-02 15:04:37 +08:00
import { createRouterGuard } from './guard';
import { routes } from './routes';
2024-05-19 21:20:42 +08:00
/**
* @zh_CN vue-router实例
*/
const router = createRouter({
history: createWebHashHistory(import.meta.env.VITE_PUBLIC_PATH),
// 应该添加到路由的初始路由列表。
routes,
scrollBehavior: (_to, _from, savedPosition) => {
// if (to.path !== from.path) {
// const app = document.querySelector('#app');
// if (app) {
// app.scrollTop = 0;
// }
// }
2024-05-19 21:20:42 +08:00
return savedPosition || { left: 0, top: 0 };
},
});
/**
* @zh_CN
*/
function resetRoutes() {
// 获取静态路由所有节点包含子节点的 name并排除不存在 name 字段的路由
const staticRouteNames = traverseTreeValues<
RouteRecordRaw,
RouteRecordName | undefined
>(routes, (route) => {
2024-05-19 21:20:42 +08:00
// 这些路由需要指定 name防止在路由重置时不能删除没有指定 name 的路由
if (import.meta.env.DEV && !route.name) {
2024-05-19 21:20:42 +08:00
console.warn(
2024-06-02 22:13:15 +08:00
`The route with the path ${route.path} needs to have the field name specified.`,
2024-05-19 21:20:42 +08:00
);
}
return route.name;
});
const { getRoutes, hasRoute, removeRoute } = router;
const allRoutes = getRoutes();
allRoutes.forEach(({ name }) => {
2024-05-19 21:20:42 +08:00
// 存在于路由表且非白名单才需要删除
if (name && !staticRouteNames.includes(name) && hasRoute(name)) {
removeRoute(name);
}
});
}
// 创建路由守卫
2024-06-02 15:04:37 +08:00
createRouterGuard(router);
2024-05-19 21:20:42 +08:00
export { resetRoutes, router };