From 251d2411f235e23209d57173857e05b637729ce8 Mon Sep 17 00:00:00 2001 From: LiuHao <liuhaoai545@gmail.com> Date: 星期日, 02 四月 2023 01:01:56 +0800 Subject: [PATCH] refactor ts --- src/components/Breadcrumb/index.vue | 56 +++++++++++++++++++++++++++----------------------------- 1 files changed, 27 insertions(+), 29 deletions(-) diff --git a/src/components/Breadcrumb/index.vue b/src/components/Breadcrumb/index.vue index 489cba1..1d138e4 100644 --- a/src/components/Breadcrumb/index.vue +++ b/src/components/Breadcrumb/index.vue @@ -1,57 +1,55 @@ -<template> - <el-breadcrumb class="app-breadcrumb" separator="/"> - <transition-group name="breadcrumb"> - <el-breadcrumb-item v-for="(item,index) in levelList" :key="item.path"> - <span v-if="item.redirect === 'noRedirect' || index == levelList.length - 1" class="no-redirect">{{ item.meta.title }}</span> - <a v-else @click.prevent="handleLink(item)">{{ item.meta.title }}</a> - </el-breadcrumb-item> - </transition-group> - </el-breadcrumb> -</template> +<script setup lang="ts"> +import { RouteLocationMatched } from 'vue-router' -<script setup> const route = useRoute(); const router = useRouter(); -const levelList = ref([]) +const levelList = ref<RouteLocationMatched[]>([]) -function getBreadcrumb() { +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: '棣栭〉' } }].concat(matched) + matched = ([{ path: '/index', meta: { title: '棣栭〉' } }] as any).concat(matched) } - levelList.value = matched.filter(item => item.meta && item.meta.title && item.meta.breadcrumb !== false) } -function isDashboard(route) { - const name = route && route.name +const isDashboard = (route: RouteLocationMatched) => { + const name = route && route.name as string if (!name) { return false } return name.trim() === 'Index' } -function handleLink(item) { +const handleLink = (item: RouteLocationMatched) => { const { redirect, path } = item - if (redirect) { - router.push(redirect) - return - } - router.push(path) + redirect ? router.push(redirect as string) : router.push(path) } watchEffect(() => { // if you go to the redirect page, do not update the breadcrumbs - if (route.path.startsWith('/redirect/')) { - return - } + if (route.path.startsWith('/redirect/')) return getBreadcrumb() }) -getBreadcrumb(); +onMounted(() => { + getBreadcrumb(); +}) </script> -<style lang='scss' scoped> +<template> + <el-breadcrumb class="app-breadcrumb" separator="/"> + <transition-group name="breadcrumb"> + <el-breadcrumb-item v-for="(item, index) in levelList" :key="item.path"> + <span v-if="item.redirect === 'noRedirect' || index == levelList.length - 1" class="no-redirect">{{ + item.meta?.title }}</span> + <a v-else @click.prevent="handleLink(item)">{{ item.meta?.title }}</a> + </el-breadcrumb-item> + </transition-group> + </el-breadcrumb> +</template> + +<style lang="scss" scoped> .app-breadcrumb.el-breadcrumb { display: inline-block; font-size: 14px; @@ -63,4 +61,4 @@ cursor: text; } } -</style> \ No newline at end of file +</style> -- Gitblit v1.9.3