2.0 KiB
Executable File
2.0 KiB
Executable File
2.1-add Route注意
使用 addRoute 方法会有以下 bug
一、刷新浏览器回跳到404页面
原因
{ path: '*', redirect: '/404', hidden: true }
复制代码
404页面在静态路由里面,动态路由拼接到动态路由后面,因此会先进入404页面
解决方案
把静态路由里面的 404路由规则删除 添加到动态路由最后面
// router.addRoute([路由配置对象])
// 引入静态路由
import { constantRoutes } from '@/router/index'
// 根据角色作用有的权限来 过滤动态路由
const menus = store.state.user.userInfo.roles.menus
const filterasyncRoutes = asyncRoutes.filter(item => {
return menus.includes(item.children[0].name)
})
// 把 404 页面添加到最后面
filterasyncRoutes.push({ path: '*', redirect: '/404', hidden: true })
router.addRoute(filterasyncRoutes)
await store.commit('menus/setMenusList', filterasyncRoutes)
二、刷新页面会白屏
解决方案
在路由前置守卫里面的 next() 里面添加
if (store.state.user.userInfo.userId) {
next()
} else {
// ...
// 解决刷新出现的白屏bug
next({
...to, // next({ ...to })的目的,是保证路由添加完了再进入页面 (可以理解为重进一次)
replace: true // 重进一次, 不保留重复历史
})
}
复制代码
三、菜单异常-控制台报错路由重复
原因
路由设置是通过router.addRoute(filterRoutes)
来添加的,退出时,并没有清空,再次登陆,又加了一次,所以有重复。
需要将路由权限重置 (恢复默认) 将来登录后再次追加才可以,不然的话,就会重复添加
解决方案
// 重置路由
export function resetRouter() {
const newRouter = createRouter()
router.matcher = newRouter.matcher // 重新设置路由的可匹配路径
}
复制代码
这个方法就是将路由重新实例化,相当于换了一个新的路由,之前
加的路由
就不存在了,需要在 登出的时候,调用一下即可