[vue-router] Duplicate named routes definition: { name: “settings“, path: “/settings/“ }路由重复

产生的原因:退出系统,在今日的时候会报路由重复的警告,刷新信息的时候是没有的,因为这使用router.addRoutes动态添加路由,退出系统的时候并没有清除动态路由,所以会报错误

效果:

解决方式:退出项目系统的时候清空路由

在router的index.vue中已经定义了方法:

// 清除动态路由

export function resetRouter(){
const newRouter= createRouter()
router.matcher = newRouter.matcher // reset router
}

这个方法就是将路由重新实例化,相当于换了一个新的路由,之前加的路由就不存在了,需要在登出的时候, 调用一下即可

在store/modules/user.js

import { resetRouter } from '@/router'

// 退出的action操作

logout(context) {

// 1. 移除vuex个人信息

context.commit('removeUserInfo')

// 2. 移除token信息

context.commit('removeToken')

// 3. 重置路由

resetRouter()

}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值