vue动态添加路由后刷新页面白屏问题及解决
作者:小只笨笨狗~
vue动态添加路由后刷新页面白屏
作为一个前端新手,项目中遇到权限处理时,通常会采用动态添加路由的方法来实现,此方法会在登陆时利用vuex将用户信息以及菜单栏需要展示的菜单路由保存,这样在用户第一次登陆项目时,动态渲染的菜单路由页面一切正常,但是当再次刷新的时候,就会出现白屏现象。。查阅了很多网站,教程代码一大堆,果断放弃,最后请教了我师父,一句话解决!
解决思路
页面刷新白屏其实是因为vuex引起的,由于刷新页面vuex数据会丢失,所以动态添加路由这一步也就失效了(之前以为,将动态添加的路由存储在了sessionStorage中,就不会vuex刷新数据丢失的影响,师父解惑:在通过vuex中的state属性存储路由在sessionStorage中,只是存储了左侧菜单栏展示的信息path地址,但是并没有存进去路由详细信息,比如name,meta值,利用vue插件即可看到本地route里面的真实数据!所以;只需要添加路由守卫,在每次页面刷新的时候都来判断是否添加的动态路由【这里设置一个变量记录是否添加的布尔值】,如果为false,即再次执行一遍添加动态路由的过程即可next()!!大功告成)
详细步骤:详细代码上一篇文章有,步骤只解决白屏问题!
1、在store.js中的mutations中添加动态路由;
第一次 addRouters(state.asyncrouters)由于state.asyncrouters是常量路由和动态路由的合并,这样添加会造成路由的重复添加----所以将异步路由拉出来添加就不会造成重复。
2、目的:在路由守卫中判断变量为false时,调用此方法在执行一遍:动态添加路由!
3、如果操作完成还是白屏-------请注意黄色框中的next()的改变!
vue动态添加路由后刷新失效
当添加路由addRoutes的时候,正常点击是没问题的,但是刷新一次页面,那么动态添加的路由就会失效,
用getRoutes() 打印出来看的时候确定路由已经添加进去了,所以这个原因应该是
当你执行到addRoutes
时,路由要添加进去了,但是,路由不是响应式的,从执行循序来看,地址栏快于路由的添加,那找不到这个路径了就只能白屏了,除非设置了404
的页面
那么怎么解决这个问题, 只需要再进行一次拦截就好了,代码如下:
实测过,这样已经解决刷新页面空白的问题了,
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。