Vue動態(tài)路由路徑重復(fù)及刷新丟失頁面問題的解決
Vue動態(tài)路由路徑重復(fù)及刷新丟失頁面
1.使用router.addRoutes(teacherRouter);
添加完路由切換路由時,vue會警告路由名字重復(fù)
問題出現(xiàn)原因是:動態(tài)路由添加時調(diào)傭addRoutes();它只會幫你注入路由,不會幫你把前面的路由清掉。如此一來就重復(fù)添加了。
解決方法:路由動態(tài)添加關(guān)鍵頁面需要在路由配置頁(router/index.js)添加自定義方法
router.$addRoutes = params => {
? router.matcher = new Router({
? ? routes: router.options.routes
// 關(guān)鍵代碼
? }).matcher;
? router.addRoutes(params);
};2.問題
在添加后進(jìn)行頁面刷新后,動態(tài)添加的路由會消失,路勁找不到
可以使用localstorage緩存,頁面路由權(quán)限判斷頁(promission.js)用了路由beforeEach可以直接判斷路由刷新:
if (from.name === null) {
? ? ? // 刷新
? ? ? router.$addRoutes(accessRoutes);
? ? ? // 確保頁面加載完成
? ? ? next({ ...to, replace: true });
? }?3.問題
切換不同角色權(quán)限,之前動態(tài)添加的路由沒有被清除,進(jìn)入看到的還是上次進(jìn)入的權(quán)限頁面。
問題在于vue的store沒有被清空,把store里的route清空就行:
可以在退出登錄設(shè)置,也可以在添加路由時清空,以下代碼為store內(nèi)permission.js添加動態(tài)路由前清空路由
const mutations = {
? SET_ROUTES: (state, routes) => {
? ? state.addRoutes = routes;
? ? state.routes = constantRoutes.concat(routes);
? },
? RESET_ROUTES: (state, payLoad) => {
? ? state.addRoutes = [];
? ? state.routes = [];
? }
};?generateRoutes({ commit }, roles) {
? ? return new Promise(resolve => {
? ? ? // 關(guān)鍵代碼 == 添加路由前將路由重置為空
? ? ? commit("RESET_ROUTES");
? ? ? // 設(shè)置登錄的路由權(quán)限
? ? ? let accessedRoutes;
? ?
? ? ?if (roles === 4) {
? ? ? ? // 教師登錄
? ? ? ?accessedRoutes = teacherRouter;
? ? ?}
? ? ?if (roles === 3) {
? ? ? ?// 學(xué)生登錄
? ? ? ?accessedRoutes = studentRouter;
? ? ?}
? ? ?commit("SET_ROUTES", accessedRoutes);
? ? ?resolve(accessedRoutes);
? ?});?Vue路由動態(tài)添加重復(fù)警告重復(fù)
動態(tài)添加路由后,控制臺警告重復(fù),在router.js中添加下面代碼
const createRouter = () => new Router({
?? ? mode: 'history',
?? ? routes: constantRoutes
})
const router = createRouter()
export function resetRouter () {
?? ?const newRouter = createRouter()
?? ?router.matcher = newRouter.matcher
}
export default routeraddRoutes()方法是router自帶的原生方法,是動態(tài)添加路由的,它并沒有刪除之前路由中原有的路由所以在permission.js中引入router,并且添加在addRoutes之前resetRouter
import router,{resetRouter} from './router'
store.dispatch('GenerateRoutes').then(accessRoutes => {
? ? // 根據(jù)roles權(quán)限生成可訪問的路由表
?? ?resetRouter()
?? ?router.addRoutes(accessRoutes)// 動態(tài)添加可訪問路由表
})總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue中用watch一次監(jiān)聽多個值變化的示例詳解
在Vue中,watch 本身不能監(jiān)聽多個變量,但我們可以通過返回具有計算屬性的對象然后監(jiān)聽該對象,從而實現(xiàn)一次性“監(jiān)聽多個變量”,本文給大家介紹了Vue中用watch一次監(jiān)聽兩個值變化的示例,需要的朋友可以參考下2024-01-01
淺談Vue static 靜態(tài)資源路徑 和 style問題
這篇文章主要介紹了淺談Vue static 靜態(tài)資源路徑 和 style問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue3.0使用vue-pdf-embed在線預(yù)覽pdf 控制頁碼顯示范圍不生效問題解決
這篇文章主要介紹了vue3.0使用vue-pdf-embed在線預(yù)覽pdf 控制頁碼顯示范圍不生效問題的問題及解決方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-01-01

