vue路由页面刷新跳转,不让页面刷新,怎么做

这是我登录的页面登录成功之後跳会成功跳转到catchOrder页面,但是页面的click/hover等事件都不管用重新刷新页面就可以了,这是为啥在线求解

最近在公司做知识储备有个权限的问题干扰了我2天,今天终于把他理顺了!!!

我想做的是后台管理系统的权限管理(所有的数据都是使用mockJs模拟得来),登录的时候发送表单验证,验证成功后后台返回权限列表,权限不同返回的列表不同,拿到权限列表后把权限列表渲染出来在页面侧边栏上。

(1) 前端提前设置静态的权限列表通常只包括页面公共的部分,比如 login

(2)前端提前定义所有的权限列表,将其定义为一个数组该數组中包含所有的权限。

(3)后台返回的数据是该用户拥有的所有权限列表一般写成路由形式,但只包含name即可如:

(1)当用户点击登錄的时候,验证成功后可以获取当前用户的id(token)存储到sessionStorage中。

(2)根据 '后台返回的权限列表(getList)'去比对 '我们提前定义好的权限列表(powerList)',然后得出 '应该动态添加的权限列表(list)' 并存放到vuex中,最后执行addRoutes把比对出来的权限路由列表动态添加到路由中即可

(3)进入home页面,渲染侧边栏

(1)vuex中数据存储在内存中,刷新后失效需要重新获取因此会出现动态页面失效问题。我们需要根据是否为刷新页面来重新加載即可

(2)进入动态加载的页面,然后再刷新也会出现上面的情况

在router的全局导航守卫beforeEach中设置,根据vuex中是否有list 来判断是否为刷新页面洳果有那么是第一次登陆, 如果没有那么就为刷新页面,需要重新执行即可

getRoutes就是执行路由对比,然后执行addRoutes的函数因为其中有获取后囼的路由列表这一步,为异步操作所以应该放在action中

我要回帖

更多关于 vue路由页面刷新 的文章

 

随机推荐