1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > vue使用addrouter添加动态路由

vue使用addrouter添加动态路由

时间:2023-04-29 01:41:51

相关推荐

vue使用addrouter添加动态路由

路由拦截beforeEach和addRouter

注意:

1.一定要理解beforeEach(全局的路由守卫,每一次路由执行都会触发)和addRoutes的运行机制,这里容易陷入死循环,所以一定要做好判断,不要每一次路由调用都执行addRouter的方法

2.使用 addRoutes 钩子后, 直接调用 next() , 如果当前页面的路由是通过 addRoutes 添加进去的,对应的路由不会渲染,当前访问是没法跳转进去的, 所以需要调用 next, 重定向当前的路由(next({…to, replace: true}))

理解:当进入 路由的 前置钩子 (router.beforEach) 的时候,本次跳转时, 路由的结构没有变化,所以我们会认为router.addRoutes没有生效,打印router的option也没有出现新加的路由(其实router.options里面打印不出动态路由,生效了也无法在options里面找到)

let hasMenus = false //判断是否添加过路由router.beforeEach((to, from, next) => {//to: Route: 即将要进入的目标 路由对象//from: Route: 当前导航正要离开的路由//next: Function: 一定要调用该方法来 resolve 这个钩子。执行效果依赖 next 方法的调用参数。if (hasMenus) {//如果有路由,向下执行next()} else {//如果没有,添加动态路由trendsRouter.forEach(ele => {router.addRoute(ele)});hasMenus = truenext({ ...to, replace: true })}})

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。