Ant Design Pro of Vue 页签内跳转路由

多页签模式下的页签内切换页面

问题描述:在多页签模式下,无论是 $router.push()还是 $router.replace()都会打开一个新的页签,但是有些递进的页面就不需要保留上一个页面,这时就需要在页签内替换页面

1、写一个判断路由的方法,返回布尔值


//设置页签内需要替换路由的数组(以路由的name值为条件)
export const list = [
  //  从页面1跳转到页面2
  {from:'page1',to:'page2'},
  。。。more
]

//通过前后路由的name判断该路由是替换还是添加
export function needRemoveFrom(a,b){
  for(let i in list){
    if(list[i].from==b && list[i].to==a){
      return true
    }
  }
  return false
}

2、监听路由
(在页签组件:src/components/MultiTab/MultiTab.vue 中找到监听事件)


  watch: {
    '$route': function (newVal,oldVal) {
    
      //  在这里加入以下判断条件,本页面其余代码不动
      if(needRemoveFrom(newVal.name,oldVal.name)) {
        this.closeThat(oldVal.fullPath)
      }
      
    }
  },
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值