Breadcrumb.vue 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. <template>
  2. <el-breadcrumb class="app-breadcrumb hidden-sm-and-down" separator="/">
  3. <transition-group appear name="breadcrumb">
  4. <el-breadcrumb-item v-for="(item, index) in levelList" :key="item.path">
  5. <span v-if="item.redirect === 'noRedirect' || index === levelList.length - 1"
  6. class="no-redirect">{{ item.meta.title }}</span>
  7. <a v-else @click.prevent="handleLink(item)">
  8. {{ item.meta.title }}
  9. </a>
  10. </el-breadcrumb-item>
  11. </transition-group>
  12. </el-breadcrumb>
  13. </template>
  14. <script>
  15. import {defineComponent, ref, watch} from 'vue'
  16. import {useRoute, useRouter} from 'vue-router'
  17. export default defineComponent({
  18. name: 'BreadCrumb',
  19. setup() {
  20. const levelList = ref([])
  21. const route = useRoute()
  22. const router = useRouter()
  23. const getBreadcrumb = () => {
  24. let matched = route.matched.filter((item) => item.meta && item.meta.title)
  25. const first = matched[0]
  26. levelList.value = matched.filter((item) => item.meta && item.meta.title && item.meta.breadcrumb !== false)
  27. }
  28. getBreadcrumb()
  29. watch(
  30. () => route.path,
  31. () => getBreadcrumb()
  32. )
  33. const handleLink = (item) => {
  34. const {redirect, path} = item
  35. if (redirect) {
  36. router.push(redirect.toString())
  37. return
  38. }
  39. router.push(path)
  40. }
  41. return {levelList, handleLink}
  42. },
  43. })
  44. </script>
  45. <style lang="scss" scoped>
  46. .app-breadcrumb.el-breadcrumb {
  47. display: inline-block;
  48. font-size: 14px;
  49. line-height: 50px;
  50. .no-redirect {
  51. color: var(--system-header-breadcrumb-text-color);
  52. cursor: text;
  53. }
  54. a {
  55. color: var(--system-header-text-color);
  56. }
  57. }
  58. </style>