2024-11-26 14:45:42 +08:00

42 lines
1.7 KiB
TypeScript

import type { RouterHistory } from "vue-router"
import { createWebHashHistory, createWebHistory } from "vue-router"
/** 路由配置 */
interface RouterConfig {
/**
* @name 路由模式
* @description hash 模式和 html5 模式
*/
history: RouterHistory
/**
* @name 是否开启动态路由功能
* @description 1. 开启后需要后端配合,在查询用户详情接口返回当前用户可以用来判断并加载动态路由的字段(该项目用的是角色 roles 字段)
* @description 2. 假如项目不需要根据不同的用户来显示不同的页面,则应该将 dynamic: false
*/
dynamic: boolean
/**
* @name 默认角色
* @description 当动态路由功能关闭时:
* @description 1. 应该将所有路由都写到常驻路由里面(表明所有登录的用户能访问的页面都是一样的)
* @description 2. 系统自动给当前登录用户赋值一个没有任何作用的默认角色
*/
defaultRoles: Array<string>
/**
* @name 是否开启三级及其以上路由缓存功能
* @description 1. 开启后会进行路由降级(把三级及其以上的路由转化为二级路由)
* @description 2. 由于都会转成二级路由,所以二级及其以上路由有内嵌子路由将会失效
*/
thirdLevelRouteCache: boolean
}
const VITE_ROUTER_HISTORY = import.meta.env.VITE_ROUTER_HISTORY
const VITE_PUBLIC_PATH = import.meta.env.VITE_PUBLIC_PATH
export const routerConfig: RouterConfig = {
history: VITE_ROUTER_HISTORY === "hash" ? createWebHashHistory(VITE_PUBLIC_PATH) : createWebHistory(VITE_PUBLIC_PATH),
dynamic: true,
defaultRoles: ["DEFAULT_ROLE"],
thirdLevelRouteCache: false
}