breadcrumb 根据路由_vue动态路由实现多级嵌套面包屑的思路与方法

本文介绍了一种在Vue中处理动态路由多级嵌套面包屑的方法,通过状态管理Vuex来存储面包屑路径。在A、B、C页面跳转时更新面包屑列表,并使用watch监听路由变化,确保面包屑始终保持最新状态。
摘要由CSDN通过智能技术生成

前言

最近在工作中遇到了一个问题,是关于vue动态路由多级嵌套面包屑怎么弄(不是动态路由嵌套可以尝试用 this.$route.matched方法获取到path和name集合,动态的嵌套获取不到全部具体的id)

功能比如:A列表页面路由如/a,点击任意一列进入任意一个A的详情页面名字为B,/b/03(这个是动态路由弄是吧,03就是id嘛),点击B页面任意一列,再进入B的详情页名字为C,路由如/bdetail/01;现在弄面包屑要获取到的路由是刚刚打开的,如(/a;/b/03;/bdetail/01)

思路:获取所有进入的层级的路由和名称如breadlist=[{path:'/a',name:'一级'},{path:'/b/03',name:'二级'},{path:'/bdetail/01',name:'三级'}],然后遍历出来如:{{item.name}}

做法

下面贴出相关代码:

A列表页面跳转按钮:(breadNum记录面包屑层级)

B列表页面跳转按钮:

breadcrumb.vue页面:

{{item.name}}

export default{

created() {

this.getBreadcrumb();

},

data() {

return {

breadlist: '' // 路由集合

}

},

methods: {

getBreadcrumb() {

var breadNumber= this.$route.query.breadNum || 1;//url变量breadNum记录层级,默认为1,如果大于1,要添加上变量;

var breadLength=this.$store.state.breadListState.length;//目前breadlist集合数组个数

var curName=this.$route.name;

var curPath=this.$route.fullPath;

var newBread={name:curName,path:curPath};

var ishome=curName=='首页';

console.log(ishome);

if(breadNumber===1){//点击一级菜单

this.$store.commit('breadListStateRemove',1);//初始化,只有首页面包屑按钮

if(!ishome)//如果不是首页

this.$store.commit('breadListStateAdd',newBread);//当前页面添加到breadlist集合

}

else if(breadLength<=breadNumber){//如果不是一级导航,并且breadlist集合个数等于或者小于目前层级

this.$store.commit('breadListStateAdd',newBread);//要把当前路由添加到breadlist集合

}else{

this.$store.commit('breadListStateRemove',parseInt(breadNumber)+1);//如果往回点面包屑导航,截取;

}

this.breadlist=this.$store.state.breadListState;

console.log(this.breadlist);

}

},

watch: {

$route () {

this.getBreadcrumb();

}

},

}

状态管理store.js代码:

export default store = new Vuex.Store({

state: {

breadListState:[

{name:'首页',path:'/'}

]

},

mutations: {

breadListStateAdd(state,obj){

state.breadListState.push(obj);

},

breadListStateRemove(state,num){

state.breadListState=state.breadListState.slice(0,num);

}

}

})

路由route.js代码:

{

path: '/',

name: '首页',

component: Main,

redirect:'/home',

children:[

{path: '/a',name: 'A页面',component: APage},

{path: '/b/:id',name: 'B页面',component: BPage},

{path: '/bdetail/:id',name: 'C页面',component: CPage},

]

}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现动态面包屑: 1. 在路由中定义每个路由对应的面包屑信息,可以在 `meta` 属性中添加 `breadcrumb` 字段,该字段的值可以是一个字符串或者一个函数,用于生成面包屑的文本内容。 ```javascript const routes = [ { path: '/', name: 'Home', component: Home, meta: { breadcrumb: '首页' } }, { path: '/about', name: 'About', component: About, meta: { breadcrumb: '关于我们' } }, { path: '/products/:id', name: 'Product', component: Product, props: true, meta: { breadcrumb: (route) => `产品${route.params.id}` } } ] ``` 2. 在 `App.vue` 中引入 `el-breadcrumb` 组件,并在 `created` 生命周期中获取当前路由面包屑信息,并将其存储在一个数组中。 ```vue <template> <div id="app"> <el-breadcrumb separator="/"> <el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item> <el-breadcrumb-item v-for="(item, index) in breadcrumbs" :key="index">{{ item }}</el-breadcrumb-item> </el-breadcrumb> <router-view/> </div> </template> <script> export default { name: 'App', data() { return { breadcrumbs: [] } }, created() { this.updateBreadcrumbs() }, watch: { $route() { this.updateBreadcrumbs() } }, methods: { updateBreadcrumbs() { const matched = this.$route.matched const breadcrumbs = [] for (let i = 0; i < matched.length; i++) { const meta = matched[i].meta if (meta.breadcrumb) { const breadcrumb = typeof meta.breadcrumb === 'function' ? meta.breadcrumb(matched[i]) : meta.breadcrumb breadcrumbs.push(breadcrumb) } } this.breadcrumbs = breadcrumbs } } } </script> ``` 实现面包屑国际化: 1. 在 `src` 目录下创建一个 `locales` 目录,用于存放不同语言的翻译文件。 2. 在 `main.js` 中引入 `VueI18n` 库,并将其挂载到全局变量上。 ```javascript import Vue from 'vue' import VueI18n from 'vue-i18n' import App from './App.vue' Vue.config.productionTip = false Vue.use(VueI18n) const i18n = new VueI18n({ locale: 'zh-CN', messages: { 'zh-CN': require('./locales/zh-CN.json'), 'en-US': require('./locales/en-US.json') } }) new Vue({ render: h => h(App), i18n }).$mount('#app') ``` 3. 在 `locales` 目录下创建 `zh-CN.json` 和 `en-US.json` 文件,分别存放中文和英文的翻译内容。 ```json // zh-CN.json { "home": "首页", "about": "关于我们", "product": "产品{{id}}" } // en-US.json { "home": "Home", "about": "About Us", "product": "Product {{id}}" } ``` 4. 在路由的 `meta` 属性中添加 `breadcrumbKey` 字段,用于指定面包屑的翻译键名。 ```javascript const routes = [ { path: '/', name: 'Home', component: Home, meta: { breadcrumbKey: 'home' } }, { path: '/about', name: 'About', component: About, meta: { breadcrumbKey: 'about' } }, { path: '/products/:id', name: 'Product', component: Product, props: true, meta: { breadcrumbKey: 'product' } } ] ``` 5. 修改 `App.vue` 中的 `updateBreadcrumbs` 方法,使用 `$t` 方法从翻译文件中获取面包屑文本内容。 ```vue methods: { updateBreadcrumbs() { const matched = this.$route.matched const breadcrumbs = [] for (let i = 0; i < matched.length; i++) { const meta = matched[i].meta if (meta.breadcrumbKey) { const key = meta.breadcrumbKey const params = matched[i].params const breadcrumb = this.$t(key, params) breadcrumbs.push(breadcrumb) } } this.breadcrumbs = breadcrumbs } } ``` 6. 在模板中使用 `$t` 方法渲染面包屑文本内容。 ```vue <el-breadcrumb-item v-for="(item, index) in breadcrumbs" :key="index">{{ $t(item) }}</el-breadcrumb-item> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值