255 lines
8.1 KiB
TypeScript
255 lines
8.1 KiB
TypeScript
import { RouteRecordRaw } from "vue-router";
|
||
/**
|
||
* 路由path路径与文件夹名称相同,找文件可以浏览器地址快速查找,方便定位文件
|
||
*
|
||
* 路由meta对象参数,我们通常将属性放到meta对象中
|
||
* meta: {
|
||
* title: 菜单栏以及 tagsView 栏、菜单搜索名称(国际化)
|
||
* isLink: 是否是超链接菜单,开启外链条件:1、 isLink:链接地址不为空 2、isIframe: false
|
||
* isHide: 是否隐藏此路由
|
||
* isKeepAlive: 是否缓存组件状态
|
||
* isAffix: 是否固定在 tagsView 栏上
|
||
* isIframe: 是否内嵌窗口,开启条件:1、isIframe:true 2、isLike:链接地址不为空
|
||
* roles: 当前路由权限表示,取角色管理。路由控制显示、隐藏。 超级管理员:admin;普通角色:common
|
||
* icon: 菜单、tagsView 图标等
|
||
* }
|
||
*/
|
||
|
||
/**
|
||
* 路由的层级设置
|
||
* 一级children下的一级路由为menu菜单的最外层,例如:首页、系统设置、权限管理,在这里我称它为 `children下的一级路由`
|
||
* children下的一级路由内在设置children则是在一级当前菜单下再配置菜单
|
||
* 依此类推
|
||
*/
|
||
|
||
export const dynamicRoutes: RouteRecordRaw[] = [
|
||
{
|
||
path: "/",
|
||
name: "/",
|
||
redirect: "/home",
|
||
component: () => import("@/layout/index.vue"), // 容器布局-顶层路由
|
||
meta: {
|
||
isKeepAlive: true
|
||
},
|
||
// 二级路由-主要渲染页面
|
||
children: [
|
||
{
|
||
path: "/home",
|
||
name: "home",
|
||
component: () => import("@/views/home/home.vue"),
|
||
meta: {
|
||
title: "home", // 国际化
|
||
isHide: false, // 是否隐藏此路由
|
||
isKeepAlive: true, // 缓存组件状态
|
||
isAffix: true, // 固定在tagesView栏上
|
||
isLink: "", // 是否外链
|
||
isIframe: false, // 是否内嵌窗口
|
||
roles: ["admin", "common"], // 路由权限
|
||
svgIcon: "home" // 菜单图标
|
||
}
|
||
},
|
||
{
|
||
path: "/home2",
|
||
name: "home2",
|
||
component: () => import("@/views/home/home.vue"),
|
||
meta: {
|
||
title: "home", // 国际化
|
||
isHide: false, // 是否隐藏此路由
|
||
isKeepAlive: true, // 缓存组件状态
|
||
isAffix: true, // 固定在tagesView栏上
|
||
isLink: "", // 是否外链
|
||
isIframe: false, // 是否内嵌窗口
|
||
roles: ["common"], // 路由权限
|
||
svgIcon: "home" // 菜单图标
|
||
}
|
||
},
|
||
{
|
||
path: "/common-components",
|
||
name: "common-components",
|
||
redirect: "/common-components/form-component",
|
||
meta: {
|
||
title: "common-components",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: true,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
svgIcon: "set"
|
||
},
|
||
children: [
|
||
{
|
||
path: "/common-components/form-component",
|
||
name: "form-component",
|
||
component: () => import("@/views/common-components/form-component/form-component.vue"),
|
||
meta: {
|
||
title: "form-component",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
}
|
||
},
|
||
{
|
||
path: "/common-components/dynamic-form",
|
||
name: "dynamic-form",
|
||
component: () => import("@/views/common-components/dynamic-form/dynamic-form.vue"),
|
||
meta: {
|
||
title: "dynamic-form",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
}
|
||
}
|
||
]
|
||
},
|
||
{
|
||
path: "/multilevel-menu",
|
||
name: "multilevel-menu",
|
||
redirect: "/multilevel-menu/second-menu",
|
||
meta: {
|
||
title: "multilevel-menu",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: true,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
svgIcon: "switch"
|
||
},
|
||
children: [
|
||
{
|
||
path: "/multilevel-menu/second-menu-1",
|
||
name: "second-menu-1",
|
||
component: () => import("@/views/multilevel-menu/second-menu/second-menu-1.vue"),
|
||
meta: {
|
||
title: "second-menu-1",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
}
|
||
},
|
||
{
|
||
path: "/multilevel-menu/second-menu-2",
|
||
name: "second-menu-2",
|
||
meta: {
|
||
title: "second-menu-2",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
},
|
||
children: [
|
||
{
|
||
path: "/multilevel-menu/third-menu-1",
|
||
name: "third-menu-1",
|
||
component: () => import("@/views/multilevel-menu/third-menu/third-menu-1.vue"),
|
||
meta: {
|
||
title: "third-menu-1",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
}
|
||
},
|
||
{
|
||
path: "/multilevel-menu/third-menu-2",
|
||
name: "third-menu-2",
|
||
component: () => import("@/views/multilevel-menu/third-menu/third-menu-2.vue"),
|
||
meta: {
|
||
title: "third-menu-2",
|
||
isLink: "",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isIframe: false,
|
||
roles: ["admin"],
|
||
icon: "icon-menu"
|
||
}
|
||
}
|
||
]
|
||
}
|
||
]
|
||
},
|
||
{
|
||
path: "/about-project",
|
||
name: "about-project",
|
||
component: () => import("@/views/about-project/about-project.vue"),
|
||
meta: {
|
||
title: "about-project",
|
||
isHide: false,
|
||
isKeepAlive: true,
|
||
isAffix: false,
|
||
isLink: "",
|
||
isIframe: false,
|
||
roles: ["admin", "common"],
|
||
svgIcon: "about"
|
||
}
|
||
}
|
||
]
|
||
}
|
||
];
|
||
|
||
/**
|
||
* 静态路由 (默认路由)
|
||
* 此路由不要动,用于做静态路由定向,如果要添加路由,请在 `dynamicRoutes数组` 中添加
|
||
* @description 前端控制路由 直接改 dynamicRoutes 中的路由,后端控制则不需要,请求接口路由数据时,覆盖 dynamicRoutes 第一个顶层 children 的内容(全屏,不包括 lauyout 中的路由出口)
|
||
* @returns 返回路由菜单数据
|
||
*/
|
||
export const staticRoutes = [
|
||
{
|
||
path: "/login",
|
||
name: "login",
|
||
component: () => import("@/views/login/login.vue"),
|
||
meta: {
|
||
title: "登录"
|
||
}
|
||
}
|
||
/**
|
||
* 提示:写在这里的为全屏界面,不建议写在这里
|
||
* 非全屏界面,请写在 dynamicRoutes 路由数组中
|
||
*/
|
||
];
|
||
|
||
/**
|
||
* 定义404、401界面
|
||
* @link 参考:https://router.vuejs.org/zh/guide/essentials/history-mode.html#netlify
|
||
*/
|
||
export const notFoundAndNoPower = [
|
||
{
|
||
path: "/401",
|
||
name: "noPower",
|
||
component: () => import("@/views/error/401.vue"),
|
||
meta: {
|
||
title: "notFound",
|
||
isHide: true
|
||
}
|
||
},
|
||
{
|
||
path: "/:path(.*)*", // 匹配任意路由,兜底,未找到页面的时候跳转该页面
|
||
name: "notFound",
|
||
component: () => import("@/views/error/404.vue"),
|
||
meta: {
|
||
title: "notFound",
|
||
isHide: true
|
||
}
|
||
}
|
||
];
|