如何解決ElementUI導(dǎo)航欄重復(fù)點(diǎn)菜單報(bào)錯(cuò)問題
ElementUI 導(dǎo)航欄重復(fù)點(diǎn)菜單報(bào)錯(cuò)
在使用ElementUI中的導(dǎo)航時(shí),默認(rèn)情況下如果重復(fù)點(diǎn)擊某選項(xiàng),會(huì)報(bào)錯(cuò)。
element-ui.common.js?b705:3354 Error: Avoided redundant navigation to current location: “/home/home1”.
at createRouterError (vue-router.esm.js?8c4f:2060)
at createNavigationDuplicatedError (vue-router.esm.js?8c4f:2033)
at HashHistory.confirmTransition (vue-router.esm.js?8c4f:2182)
at HashHistory.transitionTo (vue-router.esm.js?8c4f:2123)
at HashHistory.push (vue-router.esm.js?8c4f:2582)
at VueRouter.push (vue-router.esm.js?8c4f:2903)
at VueComponent.routeToItem (element-ui.common.js?b705:3381)
at VueComponent.handleItemClick (element-ui.common.js?b705:3348)
at invokeWithErrorHandling (vue.runtime.esm.js?2b0e:1854)
at VueComponent.Vue.$emit (vue.runtime.esm.js?2b0e:3888)
如圖所示:

可以在router的配置文件中(router -> index.js)加上下面這句話,注意位置:
// 解決ElementUI導(dǎo)航欄中的vue-router在3.0版本以上重復(fù)點(diǎn)菜單報(bào)錯(cuò)問題
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location) {
return originalPush.call(this, location).catch(err => err)
}問題即可解決。
ElementUI 菜單導(dǎo)航重定向報(bào)錯(cuò)處理
當(dāng)我們使用ElementUI中的菜單導(dǎo)航時(shí),配置好菜單路由后,重復(fù)點(diǎn)擊同一個(gè)菜單項(xiàng)會(huì)報(bào)錯(cuò),如下:
Error: Avoided redundant navigation to current location: “/xxx”.
還有一個(gè)錯(cuò)誤是,我配置了一個(gè)路由守衛(wèi),當(dāng)用戶還沒有登錄的時(shí)候,點(diǎn)擊菜單項(xiàng)時(shí),如果沒有登錄則會(huì)跳轉(zhuǎn)至登錄頁面進(jìn)行登錄,這時(shí)頁面可以正常跳轉(zhuǎn)但是也會(huì)報(bào)出錯(cuò)誤,如下:
Error: Redirected when going from “/xxx” to “/yyy” via a navigation guard.
這個(gè)問題困擾了我兩天,查了一些資料也沒有解決,直到看到一個(gè)文章,寫的是解決第一個(gè)問題的方法,如下:
import VueRouter from 'vue-router'
const originalPush = VueRouter.prototype.push
VueRouter.prototype.push = function push(location) {
? return originalPush.call(this, location).catch(err => err)
}在引入vue-router的地方加入此代碼塊,就能解決重復(fù)點(diǎn)擊同一菜單項(xiàng)的報(bào)錯(cuò),但是神奇的是,我的第二個(gè)問題也因此解決了。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于Vue3與免費(fèi)滿血版DeepSeek實(shí)現(xiàn)無限滾動(dòng)+懶加載+瀑布流模塊及優(yōu)化過程
在進(jìn)行非完全標(biāo)準(zhǔn)化數(shù)據(jù)的可視化展示時(shí),瀑布流是一種經(jīng)常被采用的展示方法,瀑布流能夠有效地將不同大小規(guī)格的內(nèi)容以一種相對(duì)規(guī)整的方式呈現(xiàn)出來,本文給大家介紹了基于Vue3與免費(fèi)滿血版DeepSeek實(shí)現(xiàn)無限滾動(dòng)+懶加載+瀑布流模塊,需要的朋友可以參考下2025-03-03
Vue動(dòng)態(tài)獲取數(shù)據(jù)后控件不可編輯問題
這篇文章主要介紹了Vue動(dòng)態(tài)獲取數(shù)據(jù)后控件不可編輯問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue3+vite實(shí)現(xiàn)版本更新檢查的示例代碼
本文描述了一個(gè)Vue3和Vite項(xiàng)目中實(shí)現(xiàn)版本更新檢查的解決方案,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-11-11
vue移動(dòng)端項(xiàng)目渲染pdf步驟及問題小結(jié)
這篇文章主要介紹了vue移動(dòng)端項(xiàng)目渲染pdf步驟,vue-pdf的插件在使用的過程中是連連踩坑的,基本遇到3個(gè)問題,分別在文中給大家詳細(xì)介紹,需要的朋友可以參考下2022-08-08
element-ui自定義message-box自定義樣式不生效的解決
這篇文章主要介紹了element-ui自定義message-box自定義樣式不生效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09

