鍍金池/ 問(wèn)答/Linux  網(wǎng)絡(luò)安全  HTML/ Vue.js 路由嵌套出現(xiàn)錯(cuò)誤,部分頁(yè)面會(huì)出現(xiàn)循環(huán)嵌套,刷新后可正常顯示

Vue.js 路由嵌套出現(xiàn)錯(cuò)誤,部分頁(yè)面會(huì)出現(xiàn)循環(huán)嵌套,刷新后可正常顯示

項(xiàng)目中使用 vue-router 的嵌套路由實(shí)現(xiàn)類似 “Layout” 的功能,具體設(shè)計(jì)如下:

訪問(wèn)地址如:http://0.0.0.0:8080/uc/member/index/index

首先是 / 路由(第一層路由),該路由組件為一個(gè)帶有 header、body、footer 的三層結(jié)構(gòu)(template),其中在 body 元素內(nèi)有一個(gè) router-view。

clipboard.png

uc 為第二層路由(會(huì)員中心),該路由是一個(gè)帶有 header-sub、sidebarcontents 的結(jié)構(gòu),其中在 contents 元素內(nèi)有一個(gè) router-view 作為動(dòng)態(tài)切換區(qū)域。

clipboard.png

當(dāng)我訪問(wèn) http://0.0.0.0:8080/uc/member/index/index 的時(shí)候,實(shí)際的路由進(jìn)行了 4 連跳,/uc -> /uc/member -> /uc/member/index - /uc/member/index/index

但是,問(wèn)題出現(xiàn)了~

clipboard.png

這種問(wèn)題是隨機(jī)性的,有些界面會(huì)出現(xiàn),有些界面不會(huì)出現(xiàn),而且,大部分情況下,刷新頁(yè)面即可恢復(fù)正常顯示。

.sidebar 中存放著一個(gè)菜單,使用 router-link 跳轉(zhuǎn)頁(yè)面,但只要其中的某個(gè)頁(yè)面出現(xiàn)顯示錯(cuò)誤,則其他的頁(yè)面也會(huì)跟著出現(xiàn)錯(cuò)誤(哪怕剛剛還是正常顯示的)!

uc 下面劃分了 member、walletagent 三個(gè)子模塊,在 .header-sub 中一個(gè)導(dǎo)航可切換,.sidebar 中的菜單可根據(jù)三個(gè)子模塊顯示不同的菜單,但,只有 member 中的頁(yè)面會(huì)出現(xiàn)上述問(wèn)題,其他兩個(gè)模塊中的頁(yè)面均不存在該問(wèn)題。

整個(gè)項(xiàng)目使用 Vue cli 構(gòu)建,大概有幾十個(gè)頁(yè)面,可復(fù)用組件頁(yè)差不多有幾十個(gè),使用 axios 請(qǐng)求數(shù)據(jù)。

驗(yàn)證的可能性有:

  • 網(wǎng)絡(luò)延遲:嘗試在頁(yè)面渲染完后再加載數(shù)據(jù),但問(wèn)題仍未解決;
  • 錯(cuò)誤的路由語(yǔ)法:把每個(gè)層級(jí)的根路由設(shè)置為 ` 或 /`,仍未解決問(wèn)題;
  • 超過(guò) 3 層路由顯示不正常,嗯,我遇到的就是這個(gè)問(wèn)題,但怎樣解決呢?

請(qǐng)問(wèn)諸位大神,還有沒(méi)有遇到類似問(wèn)題的,怎樣解決?

回答
編輯回答
久愛(ài)她

問(wèn)題的原因找到了:

  • 首先是要排除代碼中的基本警告和錯(cuò)誤,確保基本的邏輯運(yùn)行;
  • 然后就是檢查代碼有無(wú) 死循環(huán)遞歸導(dǎo)致的棧溢出;

我的代碼是因?yàn)榇嬖?遞歸導(dǎo)致的棧溢出,進(jìn)而導(dǎo)致視圖布局出錯(cuò)。我的項(xiàng)目中存在一個(gè)側(cè)邊菜單,我使用當(dāng)前路由對(duì)象的 matched 數(shù)組進(jìn)行菜單比對(duì),結(jié)果導(dǎo)致了棧溢出。

最終的解決辦法是:在比對(duì)菜單的時(shí)候優(yōu)先比對(duì)路徑(path),如果路徑一致,則繼續(xù)比對(duì)參數(shù)(query),修改后的代碼僅有10幾次循環(huán)操作,頁(yè)面在沒(méi)出現(xiàn)嵌套出錯(cuò)的情況了。類似查找某人,先排除姓、再排除名,最后確認(rèn)性別,逐漸縮小循環(huán)的層級(jí)。

2018年7月29日 09:59