vue-router重写addRoutes,优雅的解决修改vue路由不更新的问题

14 篇文章 1 订阅

最近在写项目,实现动态菜单及细粒化按钮权限功能,依托于vue-router动态路由的实现,可以实时从后端获取路由权限,并及时更新。

动态路由的实现可以看这篇完整文章:vue实现动态路由。

问题:

在使用addRoutes方法更新路由表的时候,发现从后端带来的权限信息并没有更新掉原有的路由信息。

思路:

查看vue-router文档,发现addRoutes已经不被推荐使用了,后来使用新的addRoute方法来逐个更新路由,发现并不能解决问题。api也没有提供remove路由的操作。

嗯~ 开始面向百度编程,发现普遍写法是:通过新建一个router对象然后更新替换掉原有的router对象matcher属性,来解决问题。

实现方式一般是在vu-router 的index页面写一个resetRouter方法,然后在调用addRoutes前调用resetRouter来重置router。个人觉得此种方法虽能解决问题,但不够优雅~

解决方法:

提供本人解决方法,全网首发:通过重写vueRouter对象的addRoutes方法来实现上述功能,就可以按照原来的调用方式来调用啦!

代码如下: 

const createRouter = (routes) => {
  return new VueRouter({
    mode: process.env.VUE_APP_ROUTER_MODE,
    base: process.env.BASE_URL,
    routes,
  });
};

const router = createRouter(routes);

// 重写addRoutes
const addRoutes = VueRouter.prototype.addRoutes;
VueRouter.prototype.addRoutes = function (newRoutes) {
  router.matcher = createRouter(routes).matcher; //通过重置matcher来重置router
  addRoutes.call(this, newRoutes); //调用原有方法
};

这样调用时,依旧是原来的调用方式~,不用修改其他代码啦!

router.addRoutes(dynamicRoutes); //在需要的地方调用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值