vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法
解決vue-router嵌套路由(子路由)在history模式下刷新無法渲染頁面的問題,具體內(nèi)容如下
一. 異常描述
本來使用的是vue-router的hash模式,但是hash模式下url需要帶“#”符號(hào),不僅看起來不舒服,而且有些場(chǎng)景下是會(huì)破壞路由中的"#"(微信分享頁面就會(huì)把"#"后邊的內(nèi)容處理掉),所以就需要使用history模式,然后就讓后端改下nginx配置:
location / { try_files $uri $uri/ /index.html; }
vue-router使用history模式+使用嵌套路由:
const router = new Router({ mode: 'history', routes: [ { path: '/', component: mall, name: 'mall' }, …… //我的銀行卡 { path: '/myCard', meta: { requireAuth: true }, component: myCard, name: 'myCard', children:[ { path:'', component: card}, { path:'add', component: add} ] } …… ] })
訪問路由和嵌套路由頁面,顯示正常,但是刷新頁面的時(shí)候,嵌套路由頁面就出異常了:
頁面樣式全亂了,看下頁面請(qǐng)求加載的靜態(tài)文件,所有靜態(tài)文件都是404;
二. 異常解析
1. 看下官方文檔對(duì)嵌套路由的說明:
2. 再看之前的異常頁面,看來我們的父路由成了根目錄了看下文件路徑了:
3. 看下我們引入這些異常文件,是在index.html文件中直接引用的,也就是在根路徑下引入的。之前的hash模式下,根路徑是不會(huì)變的,所以我們?cè)趇ndex.html文件中直接引入這些靜態(tài)文件,是可行的,但是使用history模式后,根路徑就不固定了。那么這種引入方式就不可行了,所以才造成了上邊出現(xiàn)的頁面無法渲染的問題:
三. 解決問題
這里有點(diǎn)尷尬,先考慮的主Vue中以Import的方式引入靜態(tài)樣式文件,的確可行,但是最后發(fā)現(xiàn),直接修改index.html文件中的靜態(tài)文件引入路徑就OK了:
修改前:
<script src="./static/js/stomp.js"></script>
修改后
<script src="/static/js/stomp.js"></script>
四. 原理
./ 是指用戶所在的當(dāng)前目錄(相對(duì)路徑);
/ 是指根目錄(絕對(duì)路徑,項(xiàng)目根目錄),也就是項(xiàng)目根目錄;
對(duì)于hash模式,根路徑是固定的,就是項(xiàng)目的根目錄,但是history模式下,以/
開頭的嵌套路徑會(huì)被當(dāng)作根路徑,所以使用“./”引入文件,就會(huì)找不到文件了,因?yàn)槲募旧砭褪窃陧?xiàng)目根目錄下的,并不在嵌套路徑這個(gè)目錄下。
總結(jié),無論hash模式還是history模式,可以直接使用“/”從項(xiàng)目根目錄引入靜態(tài)文件。
PS:之前一段時(shí)間就遇到過這個(gè)問題,百度了好久,發(fā)現(xiàn)很少有人問這個(gè)問題,有一個(gè)也沒人回答。也問了好些前端大神,還是沒能解決這個(gè)問題。也許是平時(shí)寫慣了“./” 和“../”這些開頭的路徑了吧,并沒有注意到靜態(tài)文件引入方式的問題,折騰了好些方法,最后很尷尬的發(fā)現(xiàn),其實(shí)問題很簡(jiǎn)單,只是對(duì)框架的底層了解不透徹罷了!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue-socket.io接收不到數(shù)據(jù)問題的解決方法
這篇文章主要介紹了解決vue-socket.io接收不到數(shù)據(jù)問題的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05vue-cli 打包后提交到線上出現(xiàn) "Uncaught SyntaxError:Unexpected token" 報(bào)
這篇文章主要介紹了vue-cli 打包后提交到線上出現(xiàn) "Uncaught SyntaxError:Unexpected token" 報(bào)錯(cuò),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-11-11vue中如何實(shí)現(xiàn)錨點(diǎn)定位平滑滾動(dòng)
這篇文章主要介紹了vue中如何實(shí)現(xiàn)錨點(diǎn)定位平滑滾動(dòng)方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09vue使用計(jì)算屬性完成動(dòng)態(tài)滑竿條制作
這篇文章主要介紹了vue使用計(jì)算屬性完成動(dòng)態(tài)滑竿條制作,文章圍繞計(jì)vue算屬制作動(dòng)態(tài)滑竿條的相關(guān)代碼完成內(nèi)容,需要的朋友可以參考一下2021-12-12Vue實(shí)現(xiàn)動(dòng)態(tài)查詢規(guī)則生成組件
今天我們來給大家介紹下在Vue開發(fā)中我們經(jīng)常會(huì)碰到的一種需求場(chǎng)景,本文主要介紹了Vue動(dòng)態(tài)查詢規(guī)則生成組件,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05elementUI el-input 只能輸入正整數(shù)驗(yàn)證的操作方法
這篇文章主要介紹了elementUI el-input 只能輸入正整數(shù)驗(yàn)證,本文給大家詳細(xì)講解對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-11-11Vue2.0實(shí)現(xiàn)簡(jiǎn)單分頁及跳轉(zhuǎn)效果
這篇文章主要為大家詳細(xì)介紹了Vue2.0實(shí)現(xiàn)簡(jiǎn)單數(shù)據(jù)分頁,及頁數(shù)的跳轉(zhuǎn)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07