欢迎访问 生活随笔!

凯发k8官方网

当前位置: 凯发k8官方网 > 前端技术 > vue >内容正文

vue

addroutes刷新-凯发k8官方网

发布时间:2024/10/8 vue 0 豆豆
凯发k8官方网 收集整理的这篇文章主要介绍了 addroutes刷新_vue解决addroutes多次添加路由重复的操作方法 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

本篇文章小编给大家分享一下vue解决addroutes多次添加路由重复的操作方法,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。

代码如下:

import vue from 'vue'

import router from 'vue-router'

vue.use(router)

const createrouter = () => new router({

mode: 'history',

routes: []

})

const router = createrouter()

export function resetrouter () {

const newrouter = createrouter()

router.matcher = newrouter.matcher // the relevant part

}

export default router

在登出的模块调用resetrouter方法,把原来的路由替换。

补充知识:vue中 做权限管理

使用router.addroutes()动态添加路由以及解决刷新失效,跳转后刷新失效问题

一、需求明确

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

二、注意点

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

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

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

{

"code": 0,

"message": "获取权限成功",

"data": [

{

"name": "订单管理",

"children": [

{

"name": "订单列表"

},

{

"name": "生产管理",

"children": [

{

"name": "生产列表"

}

]

},

{

"name": "退货管理"

}

]

}

]

}

三、思路与实现

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

(2)根据 '后台返回的权限列表(getlist)',去比对 '我们提前定义好的权限列表(powerlist)',然后得出

'应该动态添加的权限列表(list)' ,并存放到vuex中,最后执行addroutes把比对出来的权限路由列表动态添加到路由中即可。

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

四、问题

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

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

五、解决方法

在router的全局导航守卫beforeeach中设置,根据vuex中是否有list 来判断是否为刷新页面,如果有那么是第一次登陆,

如果没有,那么就为刷新页面,需要重新执行即可。

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

总结

以上是凯发k8官方网为你收集整理的addroutes刷新_vue解决addroutes多次添加路由重复的操作方法的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得凯发k8官方网网站内容还不错,欢迎将凯发k8官方网推荐给好友。

  • 上一篇:
  • 下一篇:
网站地图