vue router嵌套路由在history模式下重新整理無法渲染頁面問題的解決方案,vuerouter

來源:互聯網
上載者:User

vue router嵌套路由在history模式下重新整理無法渲染頁面問題的解決方案,vuerouter

解決vue-router嵌套路由(子路由)在history模式下重新整理無法渲染頁面的問題,具體內容如下

一. 異常描述

本來使用的是vue-router的hash模式,但是hash模式下url需要帶“#”符號,不僅看起來不舒服,而且有些情境下是會破壞路由中的"#"(分享頁面就會把"#"後邊的內容處理掉),所以就需要使用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}   ]  }   …… ]})

訪問路由和嵌套路由頁面,顯示正常,但是重新整理頁面的時候,嵌套路由頁面就出異常了:

頁面樣式全亂了,看下頁面請求載入的靜態檔案,所有靜態檔案都是404;

二. 異常解析

1. 看下官方文檔對嵌套路由的說明:

2. 再看之前的異常頁面,看來我們的父路由成了根目錄了看下檔案路徑了:

3. 看下我們引入這些異常檔案,是在index.html檔案中直接引用的,也就是在根路徑下引入的。之前的hash模式下,根路徑是不會變的,所以我們在index.html檔案中直接引入這些靜態檔案,是可行的,但是使用history模式後,根路徑就不固定了。那麼這種引入方式就不可行了,所以才造成了上邊出現的頁面無法渲染的問題:

三. 解決問題

這裡有點尷尬,先考慮的主Vue中以Import的方式引入靜態樣式檔案,的確可行,但是最後發現,直接修改index.html檔案中的靜態檔案引入路徑就OK了:

修改前:

<script src="./static/js/stomp.js"></script>

修改後

<script src="/static/js/stomp.js"></script>

四. 原理

./ 是指使用者所在的目前的目錄(相對路徑);

/ 是指根目錄(絕對路徑,項目根目錄),也就是項目根目錄;

對於hash模式,根路徑是固定的,就是項目的根目錄,但是history模式下,以/開頭的嵌套路徑會被當作根路徑,所以使用“./”引入檔案,就會找不到檔案了,因為檔案本身就是在項目根目錄下的,並不在嵌套路徑這個目錄下。

總結,無論hash模式還是history模式,可以直接使用“/”從項目根目錄引入靜態檔案。

PS:之前一段時間就遇到過這個問題,百度了好久,發現很少有人問這個問題,有一個也沒人回答。也問了好些前端大神,還是沒能解決這個問題。也許是平時寫慣了“./” 和“../”這些開頭的路徑了吧,並沒有注意到靜態檔案引入方式的問題,折騰了好些方法,最後很尷尬的發現,其實問題很簡單,只是對架構的底層瞭解不透徹罷了!

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.