feat: add Multi-level menu

This commit is contained in:
xiaoxian521
2021-05-21 12:55:23 +08:00
parent cd872bea83
commit 010ba1a9e1
21 changed files with 501 additions and 326 deletions

View File

@@ -0,0 +1,108 @@
import Layout from "/@/layout/index.vue";
const componentsRouter = {
path: "/components",
name: "components",
component: Layout,
redirect: "/components/split-pane",
children: [
{
path: "/components/video",
component: () => import("/@/views/components/video/index.vue"),
meta: {
title: "message.hsvideo",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/map",
component: () => import("/@/views/components/map/index.vue"),
meta: {
title: "message.hsmap",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/draggable",
component: () => import("/@/views/components/draggable/index.vue"),
meta: {
title: "message.hsdraggable",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/split-pane",
component: () => import("/@/views/components/split-pane/index.vue"),
meta: {
title: "message.hssplitPane",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/button",
component: () => import("/@/views/components/button/index.vue"),
meta: {
title: "message.hsbutton",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/cropping",
component: () => import("/@/views/components/cropping/index.vue"),
meta: {
title: "message.hscropping",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/countTo",
component: () => import("/@/views/components/count-to/index.vue"),
meta: {
title: "message.hscountTo",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/selector",
component: () => import("/@/views/components/selector/index.vue"),
meta: {
title: "message.hsselector",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/seamlessScroll",
component: () => import("/@/views/components/seamless-scroll/index.vue"),
meta: {
title: "message.hsseamless",
showLink: false,
savedPosition: true,
},
},
{
path: "/components/contextmenu",
component: () => import("/@/views/components/contextmenu/index.vue"),
meta: {
title: "message.hscontextmenu",
showLink: false,
savedPosition: true,
},
},
],
meta: {
icon: "el-icon-menu",
title: "message.hscomponents",
showLink: true,
savedPosition: true,
},
};
export default componentsRouter;

View File

@@ -0,0 +1,27 @@
import Layout from "/@/layout/index.vue";
const editorRouter = {
path: "/editor",
name: "editor",
component: Layout,
redirect: "/editor/index",
children: [
{
path: "/editor/index",
component: () => import("/@/views/editor/index.vue"),
meta: {
title: "message.hseditor",
showLink: false,
savedPosition: true,
},
},
],
meta: {
icon: "el-icon-edit-outline",
title: "message.hseditor",
showLink: true,
savedPosition: true,
},
};
export default editorRouter;

View File

@@ -0,0 +1,36 @@
import Layout from "/@/layout/index.vue";
const errorRouter = {
path: "/error",
name: "error",
component: Layout,
redirect: "/error/401",
children: [
{
path: "/error/401",
component: () => import("/@/views/error/401.vue"),
meta: {
title: "message.hsfourZeroOne",
showLink: false,
savedPosition: true,
},
},
{
path: "/error/404",
component: () => import("/@/views/error/404.vue"),
meta: {
title: "message.hsfourZeroFour",
showLink: false,
savedPosition: true,
},
},
],
meta: {
icon: "el-icon-position",
title: "message.hserror",
showLink: true,
savedPosition: true,
},
};
export default errorRouter;

View File

@@ -0,0 +1,27 @@
import Layout from "/@/layout/index.vue";
const flowChartRouter = {
path: "/flowChart",
name: "flowChart",
component: Layout,
redirect: "/flowChart/index",
children: [
{
path: "/flowChart/index",
component: () => import("/@/views/flow-chart/index.vue"),
meta: {
title: "message.hsflowChart",
showLink: false,
savedPosition: true,
},
},
],
meta: {
icon: "el-icon-set-up",
title: "message.hsflowChart",
showLink: true,
savedPosition: true,
},
};
export default flowChartRouter;

View File

@@ -0,0 +1,27 @@
import Layout from "/@/layout/index.vue";
const homeRouter = {
path: "/",
name: "home",
component: Layout,
redirect: "/welcome",
children: [
{
path: "/welcome",
name: "welcome",
component: () => import("/@/views/welcome.vue"),
meta: {
title: "message.hshome",
showLink: true,
savedPosition: false,
},
},
],
meta: {
icon: "el-icon-s-home",
showLink: true,
savedPosition: false,
},
};
export default homeRouter;

View File

@@ -0,0 +1,96 @@
import Layout from "/@/layout/index.vue";
const nestedRouter = {
path: "/nested",
component: Layout,
redirect: "/nested/menu1/menu1-1",
name: "Nested",
meta: {
title: "message.hsmenus",
icon: "el-icon-s-data",
showLink: true,
savedPosition: false,
},
children: [
{
path: "menu1",
component: () => import("/@/views/nested/menu1/index.vue"),
name: "Menu1",
meta: {
title: "message.hsmenu1",
showLink: true,
savedPosition: false,
},
redirect: "/nested/menu1/menu1-1",
children: [
{
path: "menu1-1",
component: () => import("/@/views/nested/menu1/menu1-1/index.vue"),
name: "Menu1-1",
meta: {
title: "message.hsmenu1-1",
showLink: true,
savedPosition: false,
},
},
{
path: "menu1-2",
component: () => import("/@/views/nested/menu1/menu1-2/index.vue"),
name: "Menu1-2",
redirect: "/nested/menu1/menu1-2/menu1-2-1",
meta: {
title: "message.hsmenu1-2",
showLink: true,
savedPosition: false,
},
children: [
{
path: "menu1-2-1",
component: () =>
import("/@/views/nested/menu1/menu1-2/menu1-2-1/index.vue"),
name: "Menu1-2-1",
meta: {
title: "message.hsmenu1-2-1",
showLink: true,
savedPosition: false,
},
},
{
path: "menu1-2-2",
component: () =>
import("/@/views/nested/menu1/menu1-2/menu1-2-2/index.vue"),
name: "Menu1-2-2",
meta: {
title: "message.hsmenu1-2-2",
showLink: true,
savedPosition: false,
},
},
],
},
{
path: "menu1-3",
component: () => import("/@/views/nested/menu1/menu1-3/index.vue"),
name: "Menu1-3",
meta: {
title: "message.hsmenu1-3",
showLink: true,
savedPosition: false,
},
},
],
},
{
path: "menu2",
name: "Menu2",
component: () => import("/@/views/nested/menu2/index.vue"),
meta: {
title: "message.hsmenu2",
showLink: true,
savedPosition: false,
},
},
],
};
export default nestedRouter;

View File

@@ -0,0 +1,46 @@
import Layout from "/@/layout/index.vue";
const remainingRouter = [
{
path: "/login",
name: "login",
component: () => import("/@/views/login.vue"),
meta: {
title: "message.hslogin",
showLink: false,
},
},
{
path: "/register",
name: "register",
component: () => import("/@/views/register.vue"),
meta: {
title: "message.hsregister",
showLink: false,
},
},
{
// 找不到路由重定向到404页面
path: "/:pathMatch(.*)",
component: Layout,
redirect: "/error/404",
meta: {
icon: "el-icon-s-home",
title: "message.hshome",
showLink: false,
savedPosition: false,
},
},
{
path: "/redirect",
component: Layout,
children: [
{
path: "/redirect/:path(.*)",
component: () => import("/@/views/redirect.vue"),
},
],
},
];
export default remainingRouter;

View File

@@ -0,0 +1,36 @@
import Layout from "/@/layout/index.vue";
const systemRouter = {
path: "/system",
name: "system",
component: Layout,
redirect: "/system/base",
children: [
{
path: "/system/base",
component: () => import("/@/views/system/user.vue"),
meta: {
title: "message.hsBaseinfo",
showLink: false,
savedPosition: true,
},
},
{
path: "/system/dict",
component: () => import("/@/views/system/dict/index.vue"),
meta: {
title: "message.hsDict",
showLink: false,
savedPosition: true,
},
},
],
meta: {
icon: "el-icon-setting",
title: "message.hssysManagement",
showLink: true,
savedPosition: true,
},
};
export default systemRouter;