Vue-router不允許導(dǎo)航到當(dāng)前位置(/path)錯(cuò)誤原因以及修復(fù)方式
報(bào)錯(cuò)提示
Navigating to current location ("/path") is not allowed
錯(cuò)誤原因
控制臺(tái)出現(xiàn)以上這種 Navigating to current location ("/path") is not allowed
時(shí),是因?yàn)橹貜?fù)進(jìn)入了相同路由。
錯(cuò)誤演示
為了演示報(bào)錯(cuò),用vue-cli
重新構(gòu)建了一個(gè)新的項(xiàng)目,只編寫了一個(gè)按鈕
一個(gè)input
。
code:
<!-- vue模板代碼 --> <div> <button @click="gotoHandle">測(cè)試路由跳轉(zhuǎn)</button> <input v-model="routeName"> <div>
// 路由跳轉(zhuǎn)代碼 export default { data() { return { routeName: '' } }, methods: { gotoHandle() { this.$router.push({name: this.routeName}) } } }
動(dòng)圖演示
在重復(fù)進(jìn)入相同路由時(shí)(不論是通過路徑,還是路由名稱進(jìn)入),會(huì)提示不允許導(dǎo)航到當(dāng)前位置(path
), 就像上面的例子進(jìn)入路由名為About
的路由時(shí),提示的是path: "/about"
,Navigating to current location ("/about") is not allowed。這是因?yàn)樘D(zhuǎn)的方法錯(cuò)誤時(shí),未捕獲錯(cuò)誤處理,因此直接輸出了錯(cuò)誤信息。
解決方法
方法一
直接在跳轉(zhuǎn)報(bào)錯(cuò)的那個(gè)地方加上.catch(error => error)
export default { data() { return { routeName: '' } }, methods: { gotoHandle() { this.$router.push({name: this.routeName}).catch(error => error) } } }
方法二
為跳轉(zhuǎn)錯(cuò)誤的方法全局加上錯(cuò)誤捕獲。
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
之前之后都一樣。因?yàn)槭侵刂玫?code>VueRouter原型對(duì)象上的push
事件,給原型對(duì)象的push
事件添加上了捕獲異常,所以會(huì)通過原型鏈改變所有相關(guān)對(duì)象。
replace
方法重復(fù)跳轉(zhuǎn)錯(cuò)誤與上方類似,把push
改成replace
就好。
方法三
此方法為建議方法,建議優(yōu)化跳轉(zhuǎn)邏輯,避免重復(fù)跳轉(zhuǎn)相同路由。
到此這篇關(guān)于Vue-router不允許導(dǎo)航到當(dāng)前位置(/path)錯(cuò)誤原因以及修復(fù)方式的文章就介紹到這了,更多相關(guān)Vue-router 導(dǎo)航到當(dāng)前位置內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用VUE+iView+.Net Core上傳圖片的方法示例
這篇文章主要介紹了使用VUE+iView+.Net Core上傳圖片的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01vue-router實(shí)現(xiàn)webApp切換頁(yè)面動(dòng)畫效果代碼
本篇文章主要介紹了vue實(shí)現(xiàn)app頁(yè)面切換效果實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05vue移動(dòng)端監(jiān)聽滾動(dòng)條高度的實(shí)現(xiàn)方法
今天小編就為大家分享一篇vue移動(dòng)端監(jiān)聽滾動(dòng)條高度的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09vue實(shí)現(xiàn)在一個(gè)方法執(zhí)行完后執(zhí)行另一個(gè)方法的示例
今天小編就為大家分享一篇vue實(shí)現(xiàn)在一個(gè)方法執(zhí)行完后執(zhí)行另一個(gè)方法的示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08Vue實(shí)現(xiàn)驗(yàn)證碼登錄的方法實(shí)例
最近在自己寫頁(yè)面,然后寫登錄注冊(cè)UI的時(shí)候需要一個(gè)驗(yàn)證碼組件,去搜一下沒找到什么合適的,于是自己寫一個(gè),這篇文章主要給大家介紹了關(guān)于Vue實(shí)現(xiàn)驗(yàn)證碼登錄的相關(guān)資料,需要的朋友可以參考下2022-03-03Vue項(xiàng)目數(shù)據(jù)動(dòng)態(tài)過濾實(shí)踐及實(shí)現(xiàn)思路
這篇文章主要介紹了Vue項(xiàng)目數(shù)據(jù)動(dòng)態(tài)過濾實(shí)踐,,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-09-09