vue-router3.x和vue-router4.x相互影響的問(wèn)題分析
背景
項(xiàng)目中有一個(gè)系統(tǒng)使用的微前端,主站使用是vue2實(shí)現(xiàn)的,使用的是vue-router3.x。子應(yīng)用有使用vue3實(shí)現(xiàn)的,使用的為vue-router4.x。
該子應(yīng)用中的頁(yè)面A有通過(guò)操作按鈕觸發(fā)跳轉(zhuǎn)到其他子應(yīng)用頁(yè)面B的需求,此時(shí)使用的是vue-router4.x的編程式導(dǎo)航API。
當(dāng)通過(guò)點(diǎn)擊主站的Tab切換回B的時(shí)候,使用的是主站的vue-router.3.x,到目前為止,都很正常。
但再次通過(guò)A的按鈕觸發(fā)跳轉(zhuǎn)到B時(shí),就會(huì)出現(xiàn) http://xxxxxundefined路徑,導(dǎo)致頁(yè)面空白。
分析
通過(guò)一步步斷點(diǎn),追蹤問(wèn)題。
第一次觸發(fā)跳轉(zhuǎn)時(shí)

第二次觸發(fā)跳轉(zhuǎn)時(shí)

當(dāng)vue-router4.x進(jìn)行導(dǎo)航時(shí),會(huì)先從history.state中獲取一個(gè)current字段,而vue-router3.x切換時(shí),導(dǎo)致該字段丟失了,所以最終push的路徑為undefined。
解決
在vue3的子應(yīng)用中增加以下導(dǎo)航守衛(wèi),手動(dòng)增加current字段。
router.beforeEach(() => {
// 修復(fù)通過(guò)菜單切換后(主站使用的為vue-router3.x)導(dǎo)致 history.state中丟失關(guān)鍵信息
// 再次通過(guò)vue-router4.x 的 router進(jìn)行切換時(shí),跳轉(zhuǎn)到 xxxxundefined/路徑的問(wèn)題
if (!history.state.current) {
history.state.current = window.location.pathname;
}
});到此這篇關(guān)于vue-router3.x和vue-router4.x相互影響的問(wèn)題記錄的文章就介紹到這了,更多相關(guān)vue-router3.x和vue-router4.x內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue react中的excel導(dǎo)入和導(dǎo)出功能
當(dāng)我們把信息化系統(tǒng)給用戶使用時(shí),用戶經(jīng)常需要把以前在excel里錄入的數(shù)據(jù)導(dǎo)入的信息化系統(tǒng)里,這樣為用戶提供了很大的方便,這篇文章主要介紹了vue中或者react中的excel導(dǎo)入和導(dǎo)出,需要的朋友可以參考下2023-09-09
vue指令?v-bind的使用和注意需要注意的點(diǎn)
這篇文章主要給大家分享了?v-bind的使用和注意需要注意的點(diǎn),下面文章圍繞?v-bind指令的相關(guān)資料展開(kāi)內(nèi)容且附上詳細(xì)代碼?需要的小伙伴可以參考一下,希望對(duì)大家有所幫助2021-11-11
vue中如何監(jiān)聽(tīng)url地址欄參數(shù)變化
這篇文章主要介紹了vue中如何監(jiān)聽(tīng)url地址欄參數(shù)變化問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
解決前后端分離 vue+springboot 跨域 session+cookie失效問(wèn)題
這篇文章主要介紹了前后端分離 vue+springboot 跨域 session+cookie失效問(wèn)題的解決方法,解決過(guò)程也很簡(jiǎn)單 ,需要的朋友可以參考下2019-05-05
詳解如何用VUE寫(xiě)一個(gè)多用模態(tài)框組件模版
這篇文章主要介紹了詳解如何用VUE寫(xiě)一個(gè)多用模態(tài)框組件模版,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-09-09
Vue3+vueuse實(shí)現(xiàn)放大鏡示例詳解
這篇文章主要為大家介紹了Vue3+vueuse實(shí)現(xiàn)放大鏡示例過(guò)程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
vue執(zhí)行配置選項(xiàng)npm?run?serve的本質(zhì)圖文詳解
本地開(kāi)發(fā)一般通過(guò)執(zhí)行npm run serve命令來(lái)啟動(dòng)項(xiàng)目,那這行命令到底存在什么魔法?下面這篇文章主要給大家介紹了關(guān)于vue執(zhí)行配置選項(xiàng)npm?run?serve的本質(zhì)的相關(guān)資料,需要的朋友可以參考下2023-05-05

