国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法

來源:懂視網 責編:小采 時間:2020-11-27 22:20:48
文檔

vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法

vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法:解決vue-router嵌套路由(子路由)在history模式下刷新無法渲染頁面的問題,具體內容如下 一. 異常描述 本來使用的是vue-router的hash模式,但是hash模式下url需要帶#符號,不僅看起來不舒服,而且有些場景下是會破壞路由中的#(微信分享頁面就會把
推薦度:
導讀vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法:解決vue-router嵌套路由(子路由)在history模式下刷新無法渲染頁面的問題,具體內容如下 一. 異常描述 本來使用的是vue-router的hash模式,但是hash模式下url需要帶#符號,不僅看起來不舒服,而且有些場景下是會破壞路由中的#(微信分享頁面就會把

解決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="https://www.gxlcms.com/static/js/stomp.js"></script>

四. 原理

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

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

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

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

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

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法

vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法:解決vue-router嵌套路由(子路由)在history模式下刷新無法渲染頁面的問題,具體內容如下 一. 異常描述 本來使用的是vue-router的hash模式,但是hash模式下url需要帶#符號,不僅看起來不舒服,而且有些場景下是會破壞路由中的#(微信分享頁面就會把
推薦度:
標簽: VUE 解決方法 嵌套
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 亚洲国产视频网 | 国产精品久久久久一区二区 | 亚洲国产成人久久综合碰 | 日本一区二区三区在线播放 | 日韩 欧美 中文 | 色阁阁| 人人草视频在线观看 | 成人欧美一区二区三区在线 | 日韩不卡手机视频在线观看 | 亚洲一区色 | 国产短视频精品一区二区三区 | 97热久久免费频精品99国产成人 | 亚洲一区二区三区高清 | 日韩国产欧美一区二区三区 | 久久综合中文字幕一区二区 | 欧美高清免费 | 大陆一级毛片 | 国产免费资源高清小视频在线观看 | 无毛片| 插欧美| 国产青草 | 亚洲欧美在线综合 | 国产精品久久久久9999 | 国产成人三级经典中文 | 91日韩欧美| 国产精品久久久久久久久久久久 | 欧美在线视频免费观看 | 欧美综合亚洲 | 全部费免一级毛片不收费 | 国产精品色综合久久 | 国产在线视频不卡 | 国产视频在 | 国产精品久久久久精 | 亚洲国产成人久久综合碰碰动漫3d | 成人一级免费视频 | 国产视频一区二区 | 日本一区二区三区在线观看 | 么公又大又硬又粗又爽的视频 | 国产精品91av | 免费视频一区 | 成人区精品一区二区毛片不卡 |