解决vue动态添加路由后刷新页面白屏问题

文章讲述了Vuex在页面刷新后丢失数据,从而引起动态添加路由失效导致白屏的问题。作者发现仅存储路由的path在sessionStorage中并不完整,因为缺少了name和meta等信息。解决方案是使用路由守卫,在刷新时检查是否已添加动态路由,如果未添加则重新执行添加过程。关键在于防止重复添加路由和正确设置next()。
摘要由CSDN通过智能技术生成

解决思路:页面刷新白屏其实是因为vuex引起的,由于刷新页面vuex数据会丢失,所以动态添加路由这一步也就失效了(之前以为,将动态添加的路由存储在了sessionStorage中,就不会vuex刷新数据丢失的影响,师父解惑:在通过vuex中的state属性存储路由在sessionStorage中,只是存储了左侧菜单栏展示的信息path地址,但是并没有存进去路由详细信息,比如name,meta值,利用vue插件即可看到本地route里面的真实数据!所以;只需要添加路由守卫,在每次页面刷新的时候都来判断是否添加的动态路由【这里设置一个变量记录是否添加的布尔值】,如果为false,即再次执行一遍添加动态路由的过程即可next()!!大功告成)

详细步骤:详细代码上一篇文章有,步骤只解决白屏问题!

1、在store.js中的mutations中添加动态路由;

第一次 addRouters(state.asyncrouters)由于state.asyncrouters是常量路由和动态路由的合并,这样添加会造成路由的重复添加----所以将异步路由拉出来添加就不会造成重复。

  1. 目的:在路由守卫中判断变量为false时,调用此方法在执行一遍:动态添加路由!

3、如果操作完成还是白屏-------请注意黄色框中的next()的改变!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值