提交 d52b0de8 作者: 无木

feat(route): add `hidePathForChildren` in `meta`

添加`hidePathForChildren`选项用于在子菜单中隐藏本级path
上级 72ac240f
...@@ -9,10 +9,6 @@ export function getAllParentPath<T = Recordable>(treeData: T[], path: string) { ...@@ -9,10 +9,6 @@ export function getAllParentPath<T = Recordable>(treeData: T[], path: string) {
return (menuList || []).map((item) => item.path); return (menuList || []).map((item) => item.path);
} }
function isPlainPath(path: string) {
return path.indexOf(':') === -1;
}
function joinParentPath(menus: Menu[], parentPath = '') { function joinParentPath(menus: Menu[], parentPath = '') {
for (let index = 0; index < menus.length; index++) { for (let index = 0; index < menus.length; index++) {
const menu = menus[index]; const menu = menus[index];
...@@ -24,7 +20,7 @@ function joinParentPath(menus: Menu[], parentPath = '') { ...@@ -24,7 +20,7 @@ function joinParentPath(menus: Menu[], parentPath = '') {
menu.path = `${parentPath}/${menu.path}`; menu.path = `${parentPath}/${menu.path}`;
} }
if (menu?.children?.length) { if (menu?.children?.length) {
joinParentPath(menu.children, isPlainPath(menu.path) ? menu.path : parentPath); joinParentPath(menu.children, menu.meta?.hidePathForChildren ? parentPath : menu.path);
} }
} }
} }
......
...@@ -240,6 +240,7 @@ const feat: AppRouteModule = { ...@@ -240,6 +240,7 @@ const feat: AppRouteModule = {
meta: { meta: {
title: t('routes.demo.feat.tab'), title: t('routes.demo.feat.tab'),
carryParam: true, carryParam: true,
hidePathForChildren: true,
}, },
children: [ children: [
{ {
......
...@@ -33,6 +33,9 @@ declare module 'vue-router' { ...@@ -33,6 +33,9 @@ declare module 'vue-router' {
// Never show in menu // Never show in menu
hideMenu?: boolean; hideMenu?: boolean;
isLink?: boolean; isLink?: boolean;
// only build for Menu
ignoreRoute?: boolean; ignoreRoute?: boolean;
// Hide path for children
hidePathForChildren?: boolean;
} }
} }
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论