From 3b710d9e99871509b679461f51ec1e7e239d06b0 Mon Sep 17 00:00:00 2001 From: 疯狂的狮子Li <15040126243@163.com> Date: 星期二, 26 十一月 2024 15:28:24 +0800 Subject: [PATCH] update typescript 5.4.5 => 5.7.2 update vite 5.2.12 => 5.4.11 update vue 3.4.34 => 3.5.13 update element-plus 2.7.8 => 2.8.8 update .... 其他依赖版本升级 --- src/components/Breadcrumb/index.vue | 48 ++++++++++++++++++++++++++++++++++++++++-------- 1 files changed, 40 insertions(+), 8 deletions(-) diff --git a/src/components/Breadcrumb/index.vue b/src/components/Breadcrumb/index.vue index 57a30ac..184f41c 100644 --- a/src/components/Breadcrumb/index.vue +++ b/src/components/Breadcrumb/index.vue @@ -11,20 +11,52 @@ <script setup lang="ts"> import { RouteLocationMatched } from 'vue-router'; +import usePermissionStore from '@/store/modules/permission'; const route = useRoute(); const router = useRouter(); +const permissionStore = usePermissionStore(); const levelList = ref<RouteLocationMatched[]>([]); const getBreadcrumb = () => { // only show routes with meta.title - let matched = route.matched.filter((item) => item.meta && item.meta.title); - const first = matched[0]; - // 鍒ゆ柇鏄惁涓洪椤� - if (!isDashboard(first)) { - matched = ([{ path: '/index', meta: { title: '棣栭〉' } }] as any).concat(matched); + let matched = []; + const pathNum = findPathNum(route.path); + // multi-level menu + if (pathNum > 2) { + const reg = /\/\w+/gi; + const pathList = route.path.match(reg).map((item, index) => { + if (index !== 0) item = item.slice(1); + return item; + }) + getMatched(pathList, permissionStore.defaultRoutes, matched); + } else { + matched = route.matched.filter(item => item.meta && item.meta.title); } - levelList.value = matched.filter((item) => item.meta && item.meta.title && item.meta.breadcrumb !== false); + // 鍒ゆ柇鏄惁涓洪椤� + if (!isDashboard(matched[0])) { + matched = [{ path: '/index', meta: { title: '棣栭〉' } }].concat(matched); + } + levelList.value = matched.filter(item => item.meta && item.meta.title && item.meta.breadcrumb !== false); +}; +const findPathNum = (str, char = '/') => { + let index = str.indexOf(char); + let num = 0; + while (index !== -1) { + num++; + index = str.indexOf(char, index + 1); + } + return num; +}; +const getMatched = (pathList, routeList, matched) => { + let data = routeList.find(item => item.path == pathList[0] || (item.name += '').toLowerCase() == pathList[0]); + if (data) { + matched.push(data); + if (data.children && pathList.length) { + pathList.shift(); + getMatched(pathList, data.children, matched); + } + } }; const isDashboard = (route: RouteLocationMatched) => { const name = route && (route.name as string); @@ -33,9 +65,9 @@ } return name.trim() === 'Index'; }; -const handleLink = (item: RouteLocationMatched) => { +const handleLink = (item) => { const { redirect, path } = item; - redirect ? router.push(redirect as string) : router.push(path); + redirect ? router.push(redirect) : router.push(path); }; watchEffect(() => { -- Gitblit v1.9.3