背景
項目中有一個系統(tǒng)使用的微前端,主站使用是vue2
實現(xiàn)的,使用的是vue-router3.x
。子應(yīng)用有使用vue3
實現(xiàn)的,使用的為vue-router4.x
。
該子應(yīng)用中的頁面A有通過操作按鈕觸發(fā)跳轉(zhuǎn)到其他子應(yīng)用頁面B的需求,此時使用的是vue-router4.x
的編程式導(dǎo)航API。
當(dāng)通過點擊主站的Tab切換回B的時候,使用的是主站的vue-router.3.x
,到目前為止,都很正常。
但再次通過A的按鈕觸發(fā)跳轉(zhuǎn)到B時,就會出現(xiàn) http://xxxxxundefined
路徑,導(dǎo)致頁面空白。
分析
通過一步步斷點,追蹤問題。
第一次觸發(fā)跳轉(zhuǎn)時
第二次觸發(fā)跳轉(zhuǎn)時
當(dāng)vue-router4.x進行導(dǎo)航時,會先從history.state中獲取一個current字段,而vue-router3.x切換時,導(dǎo)致該字段丟失了,所以最終push的路徑為undefined。文章來源:http://www.zghlxwxcb.cn/news/detail-426128.html
解決
在vue3的子應(yīng)用中增加以下導(dǎo)航守衛(wèi),手動增加current
字段。文章來源地址http://www.zghlxwxcb.cn/news/detail-426128.html
router.beforeEach(() => {
// 修復(fù)通過菜單切換后(主站使用的為vue-router3.x)導(dǎo)致 history.state中丟失關(guān)鍵信息
// 再次通過vue-router4.x 的 router進行切換時,跳轉(zhuǎn)到 xxxxundefined/路徑的問題
if (!history.state.current) {
history.state.current = window.location.pathname;
}
});
到了這里,關(guān)于vue-router3.x和vue-router4.x相互影響的問題記錄的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!