123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- <template>
- <div v-show="isShow" class="breadcrumb">
- <div class="breadcrumb-container">
- <router-link to="/">
- <svg-icon icon-class="homepage" />
- </router-link>
- <i class="el-icon-arrow-right" />
- <span v-for="item in routerList" :key="item.path">
- <span class="router-title">
- <template v-if="item.meta.link">
- <router-link :to="item.meta.link"> {{ $t(item.meta.title) }} </router-link>
- </template>
- <template v-else>
- {{ $t(item.meta.title) }}
- </template>
- </span>
- <i class="el-icon-arrow-right" />
- </span>
- </div>
- </div>
- </template>
- <script>
- export default {
- name: 'BreadCrumb',
- data() {
- return {
- routerList: []
- };
- },
- computed: {
- isShow() {
- return this.routerList.length > 0;
- }
- },
- watch: {
- $route() {
- this.getBreadcrumb();
- }
- },
- created() {
- this.getBreadcrumb();
- },
- methods: {
- getBreadcrumb() {
- this.routerList = this.$route.matched.filter(item => item.meta && item.meta.title);
- this.$emit('update:isShowNav', this.isShow);
- }
- }
- };
- </script>
- <style lang="scss">
- .breadcrumb {
- z-index: 999;
- width: 100%;
- height: 56px;
- line-height: 56px;
- background-color: #f6ecdd;
- &-container {
- width: $basic-width;
- min-width: $basic-width;
- height: 100%;
- padding: 15px 0;
- margin: 0 auto;
- font-weight: 700;
- line-height: 26px;
- color: #948e85;
- vertical-align: middle;
- &::before {
- display: inline-block;
- width: 6px;
- height: 100%;
- margin-right: 24px;
- vertical-align: bottom;
- content: '';
- background-color: $basic-color;
- }
- .el-icon-arrow-right {
- margin: 0 12px;
- }
- .router-title {
- cursor: pointer;
- }
- span:last-child {
- color: #000;
- .el-icon-arrow-right {
- display: none;
- }
- }
- }
- }
- </style>
|