Vue学习-组件之间跳转,右侧页面刷新,但左侧菜单栏选中状态未刷新

解决前图片:

在这里插入图片描述

解决方法: 在嵌入菜单的组件中添加路由监听
select(m){
   this.menuList.forEach(element => {
     if(element.children.length > 0){
         element.children.forEach(child =>{
           if(child.path == m){
             this.selectMenu = child;
             return;
           }
         })
       }
   });
   this.$router.push(this.selectMenu.path);
   //左侧导航栏菜单选中刷新
   this.childActiveMenu = this.selectMenu.path;
   //第一位必需。整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
   //第二位必需。要删除的项目数量。如果设置为 0,则不会删除项目。
   //第三位可选。向数组添加的新项目。
   this.breadcrumbData.splice(0,1,this.selectMenu);
 },

watch:{
  // 监听路由变化 处理两个组件之间的相互跳转,右侧页面产生变化,但左侧菜单选中状态未刷新
  $route(to, from) {
    this.select(to.path);
  },
  //处理activeName生效,但是openNames不生效的情况
  //运用Menu的updateopened方法:手动更新展开的子目录,注意要在 $nextTick 里调用。对openNames添加watch:
  parentActiveMenu() {
    this.$nextTick(() => {
      this.$refs.side_menu.updateOpened();
      this.$refs.side_menu.updateActiveName();
    })
  },
  //监听菜单数据的变化'$store.state.users.routers' 固定写法
  '$store.state.users.routers':function(){
    this.initMenuData();
  },
}
解决后图片:

在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值