Vue-router不允許導航到當前位置(/path)錯誤原因以及修復方式
報錯提示
Navigating to current location ("/path") is not allowed

錯誤原因
控制臺出現(xiàn)以上這種 Navigating to current location ("/path") is not allowed 時,是因為重復進入了相同路由。
錯誤演示
為了演示報錯,用vue-cli重新構建了一個新的項目,只編寫了一個按鈕一個input。
code:
<!-- vue模板代碼 --> <div> <button @click="gotoHandle">測試路由跳轉(zhuǎn)</button> <input v-model="routeName"> <div>
// 路由跳轉(zhuǎn)代碼
export default {
data() {
return {
routeName: ''
}
},
methods: {
gotoHandle() {
this.$router.push({name: this.routeName})
}
}
}
動圖演示

在重復進入相同路由時(不論是通過路徑,還是路由名稱進入),會提示不允許導航到當前位置(path), 就像上面的例子進入路由名為About的路由時,提示的是path: "/about",Navigating to current location ("/about") is not allowed。這是因為跳轉(zhuǎn)的方法錯誤時,未捕獲錯誤處理,因此直接輸出了錯誤信息。
解決方法
方法一
直接在跳轉(zhuǎn)報錯的那個地方加上.catch(error => error)
export default {
data() {
return {
routeName: ''
}
},
methods: {
gotoHandle() {
this.$router.push({name: this.routeName}).catch(error => error)
}
}
}
方法二
為跳轉(zhuǎn)錯誤的方法全局加上錯誤捕獲。
import VueRouter from 'vue-router'
const routerPush = VueRouter.prototype.push
VueRouter.prototype.push = function (location) {
return routerPush.call(this, location).catch(error => error)
}
以上代碼在main.js,或者router/index.js 下執(zhí)行,以及new VueRouter之前之后都一樣。因為是重置的VueRouter原型對象上的push事件,給原型對象的push事件添加上了捕獲異常,所以會通過原型鏈改變所有相關對象。
replace 方法重復跳轉(zhuǎn)錯誤與上方類似,把push改成replace就好。
方法三
此方法為建議方法,建議優(yōu)化跳轉(zhuǎn)邏輯,避免重復跳轉(zhuǎn)相同路由。
到此這篇關于Vue-router不允許導航到當前位置(/path)錯誤原因以及修復方式的文章就介紹到這了,更多相關Vue-router 導航到當前位置內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用VUE+iView+.Net Core上傳圖片的方法示例
這篇文章主要介紹了使用VUE+iView+.Net Core上傳圖片的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01
vue-router實現(xiàn)webApp切換頁面動畫效果代碼
本篇文章主要介紹了vue實現(xiàn)app頁面切換效果實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
vue移動端監(jiān)聽滾動條高度的實現(xiàn)方法
今天小編就為大家分享一篇vue移動端監(jiān)聽滾動條高度的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vue實現(xiàn)在一個方法執(zhí)行完后執(zhí)行另一個方法的示例
今天小編就為大家分享一篇vue實現(xiàn)在一個方法執(zhí)行完后執(zhí)行另一個方法的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue項目數(shù)據(jù)動態(tài)過濾實踐及實現(xiàn)思路
這篇文章主要介紹了Vue項目數(shù)據(jù)動態(tài)過濾實踐,,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-09-09

