欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue動態(tài)路由路徑重復及刷新丟失頁面問題的解決

 更新時間:2023年01月14日 09:16:26   作者:沒有傘的孩子要學會努力奔跑!  
這篇文章主要介紹了Vue動態(tài)路由路徑重復及刷新丟失頁面問題的解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

Vue動態(tài)路由路徑重復及刷新丟失頁面

1.使用router.addRoutes(teacherRouter);

添加完路由切換路由時,vue會警告路由名字重復

問題出現(xiàn)原因是:動態(tài)路由添加時調(diào)傭addRoutes();它只會幫你注入路由,不會幫你把前面的路由清掉。如此一來就重復添加了。

解決方法:路由動態(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.問題

在添加后進行頁面刷新后,動態(tài)添加的路由會消失,路勁找不到

可以使用localstorage緩存,頁面路由權(quán)限判斷頁(promission.js)用了路由beforeEach可以直接判斷路由刷新:

if (from.name === null) {
? ? ? // 刷新
? ? ? router.$addRoutes(accessRoutes);
? ? ? // 確保頁面加載完成
? ? ? next({ ...to, replace: true });
? }?

3.問題

切換不同角色權(quán)限,之前動態(tài)添加的路由沒有被清除,進入看到的還是上次進入的權(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) {
? ? ? ?// 學生登錄
? ? ? ?accessedRoutes = studentRouter;
? ? ?}

? ? ?commit("SET_ROUTES", accessedRoutes);
? ? ?resolve(accessedRoutes);
? ?});?

Vue路由動態(tài)添加重復警告重復

動態(tài)添加路由后,控制臺警告重復,在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 router

addRoutes()方法是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 elementui table編輯表單時彈框增加編輯明細數(shù)據(jù)的實現(xiàn)

    vue elementui table編輯表單時彈框增加編輯明細數(shù)據(jù)的實現(xiàn)

    在Vue項目中,通過使用Element UI框架實現(xiàn)表單及其明細數(shù)據(jù)的新增和編輯操作,主要通過彈窗形式進行明細數(shù)據(jù)的增加和編輯,有效提升用戶交互體驗,本文詳細介紹了相關(guān)實現(xiàn)方法和代碼,適合需要在Vue項目中處理復雜表單交互的開發(fā)者參考
    2024-10-10
  • Vue 中使用 typescript的方法詳解

    Vue 中使用 typescript的方法詳解

    Typescript 5年內(nèi)的熱度隨時間變化的趨勢,整體呈現(xiàn)一個上升的趨勢。也說明ts越來越️受大家的關(guān)注了。這篇文章主要介紹了Vue 中使用 typescript的方法詳解,需要的朋友可以參考下
    2020-02-02
  • vue.js中使用微信掃一掃解決invalid signature問題(完美解決)

    vue.js中使用微信掃一掃解決invalid signature問題(完美解決)

    這篇文章主要介紹了vue.js中使用微信掃一掃解決invalid signature問題(推薦),本文通過實例代碼給出解決方法,代碼簡單易懂非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • vue.js動態(tài)修改background-image問題

    vue.js動態(tài)修改background-image問題

    這篇文章主要介紹了vue.js動態(tài)修改background-image問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • 詳解el Cascader懶加載數(shù)據(jù)回顯示例

    詳解el Cascader懶加載數(shù)據(jù)回顯示例

    這篇文章主要為大家介紹了詳解el Cascader懶加載數(shù)據(jù)回顯示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 淺談Vue內(nèi)置component組件的應(yīng)用場景

    淺談Vue內(nèi)置component組件的應(yīng)用場景

    這篇文章主要介紹了淺談Vue內(nèi)置component組件的應(yīng)用場景,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • 使用 Element UI Table 的 slot-scope方法

    使用 Element UI Table 的 slot-scope方法

    這篇文章主要介紹了使用 Element UI Table 的 slot-scope方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-10-10
  • vue 使某個組件不被 keep-alive 緩存的方法

    vue 使某個組件不被 keep-alive 緩存的方法

    今天小編就為大家分享一篇vue 使某個組件不被 keep-alive 緩存的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案

    詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案

    這篇文章主要介紹了詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-06-06
  • element-plus一個vue3.xUI框架(element-ui的3.x 版初體驗)

    element-plus一個vue3.xUI框架(element-ui的3.x 版初體驗)

    這篇文章主要介紹了element-plus一個vue3.xUI框架(element-ui的3.x 版初體驗),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12

最新評論