parent
							
								
									58dbea3105
								
							
						
					
					
						commit
						9b81b86eed
					
				| @ -0,0 +1,109 @@ | ||||
| <template> | ||||
|   <el-breadcrumb class="app-breadcrumb" separator="|" style="height:50px;backgroundColor:rgba(88, 179, 81, 1);borderRadius:0px;padding:0px 20px 0px 20px;boxShadow:0px 0px 0px #f903d4;borderWidth:1px;borderStyle:none none double none;borderColor:rgba(88, 179, 81, 1);"> | ||||
|     <transition-group name="breadcrumb" class="box" :style="1==1?'justifyContent:flex-start;':1==2?'justifyContent:center;':'justifyContent:flex-end;'"> | ||||
|       <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.name }}</span> | ||||
|         <a v-else @click.prevent="handleLink(item)">{{ item.name }}</a> | ||||
|       </el-breadcrumb-item> | ||||
|     </transition-group> | ||||
|   </el-breadcrumb> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| import pathToRegexp from 'path-to-regexp' | ||||
| import { generateTitle } from '@/utils/i18n' | ||||
| export default { | ||||
|   data() { | ||||
|     return { | ||||
|       levelList: null | ||||
|     } | ||||
|   }, | ||||
|   watch: { | ||||
|     $route() { | ||||
|       this.getBreadcrumb() | ||||
|     } | ||||
|   }, | ||||
|   created() { | ||||
|     this.getBreadcrumb() | ||||
|     this.breadcrumbStyleChange() | ||||
|   }, | ||||
|   methods: { | ||||
|     generateTitle, | ||||
|     getBreadcrumb() { | ||||
|       // only show routes with meta.title | ||||
|       let route = this.$route | ||||
|       let matched = route.matched.filter(item => item.meta) | ||||
|       const first = matched[0] | ||||
|       matched = [{ path: '/index' }].concat(matched) | ||||
| 
 | ||||
|       this.levelList = matched.filter(item => item.meta) | ||||
|     }, | ||||
|     isDashboard(route) { | ||||
|       const name = route && route.name | ||||
|       if (!name) { | ||||
|         return false | ||||
|       } | ||||
|       return name.trim().toLocaleLowerCase() === 'Index'.toLocaleLowerCase() | ||||
|     }, | ||||
|     pathCompile(path) { | ||||
|       // To solve this problem https://github.com/PanJiaChen/vue-element-admin/issues/561 | ||||
|       const { params } = this.$route | ||||
|       var toPath = pathToRegexp.compile(path) | ||||
|       return toPath(params) | ||||
|     }, | ||||
|     handleLink(item) { | ||||
|       const { redirect, path } = item | ||||
|       if (redirect) { | ||||
|         this.$router.push(redirect) | ||||
|         return | ||||
|       } | ||||
|       this.$router.push(path) | ||||
|     }, | ||||
|     breadcrumbStyleChange(val) { | ||||
|       this.$nextTick(()=>{ | ||||
|         document.querySelectorAll('.app-breadcrumb .el-breadcrumb__separator').forEach(el=>{ | ||||
|           el.innerText = "|" | ||||
|           el.style.color = "rgba(88, 179, 81, 1)" | ||||
|         }) | ||||
|         document.querySelectorAll('.app-breadcrumb .el-breadcrumb__inner a').forEach(el=>{ | ||||
|           el.style.color = "rgba(88, 179, 81, 1)" | ||||
|         }) | ||||
|         document.querySelectorAll('.app-breadcrumb .el-breadcrumb__inner .no-redirect').forEach(el=>{ | ||||
|           el.style.color = "rgba(88, 179, 81, 1)" | ||||
|         }) | ||||
| 
 | ||||
|         let str = "vertical" | ||||
|         if("vertical" === str) { | ||||
|           let headHeight = "60px" | ||||
|           headHeight = parseInt(headHeight) + 10 + 'px' | ||||
|           document.querySelectorAll('.app-breadcrumb').forEach(el=>{ | ||||
|             el.style.marginTop = headHeight | ||||
|           }) | ||||
|         } | ||||
| 
 | ||||
|       }) | ||||
|     }, | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" scoped> | ||||
| .app-breadcrumb { | ||||
|   display: block; | ||||
|   font-size: 14px; | ||||
|   line-height: 50px; | ||||
| 
 | ||||
|   .box { | ||||
|     display: flex; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     justify-content: flex-start; | ||||
|     align-items: center; | ||||
|   } | ||||
| 
 | ||||
|   .no-redirect { | ||||
|     color: #97a8be; | ||||
|     cursor: text; | ||||
|   } | ||||
| } | ||||
| </style> | ||||
					Loading…
					
					
				
		Reference in new issue