Vue路由History mode模式中頁面無法渲染的原因及解決

【轉(zhuǎn)自】https://blog.csdn.net/xjlinme/article/details/74783887

Vue下路由History mode導(dǎo)致頁面無法渲染的原因

用 Vue.js + vue-router 創(chuàng)建單頁應(yīng)用,是非常簡單的昆婿。使用 Vue.js 窖认,我們已經(jīng)可以通過組合組件來組成應(yīng)用程序,當(dāng)你要把 vue-router 添加進(jìn)來阔籽,我們需要做的是散劫,將組件(components)映射到路由(routes)绣溜,然后告訴 vue-router 在哪里渲染它們。

一般開發(fā)的單頁應(yīng)用的URL都會帶有#號的hash模式伦仍,因為整個應(yīng)用本身而言就只有一個HTML结窘,其他的都是通過router來渲染。如果因為業(yè)務(wù)需要充蓝,或者單純是覺得帶#號不美觀隧枫,那么可以使用history模式,簡單而言就是在router的配置文件index.js中添加如下一行代碼:

history: mode

沒錯谓苟,這樣URL不再會有#號官脓,你會發(fā)現(xiàn)整個地址欄回到了你熟悉的那個樣子,不過涝焙,接下來介紹的就非常的重要了卑笨,可能很多剛?cè)腴T的新人或多或少都會遇見這么一兩個坑…

頁面無法渲染

這里以我寫的一個項目為例子,當(dāng)我開啟history模式的時候仑撞,我并沒有對路由進(jìn)行任何處理赤兴,在Dev階段一切都是正常的,可是打包之后隧哮,訪問項目路徑:

sdp.driver.com/driver/

會發(fā)現(xiàn)頁面一片空白桶良,但是靜態(tài)文件都能夠正常的引用,因為使用了YII中的模塊沮翔,所以除了域名之外陨帆,還會帶有driver模塊名。一般很多人創(chuàng)建的項目都放在了根目錄下面,也就是:

sdp.driver.com

這樣的一種形式疲牵,沒問題承二。可是如果配置了模塊纲爸,或者放置在了子文件夾下面亥鸠,那么就會出問題。其實缩焦,這是因為router無法找到路徑中的組件,所以也就無法渲染了责静。只需要修改router中的index.js袁滥,在每個path中加上你項目名稱就行了,這樣就能夠成功了灾螃。

index.js

最后的頁面效果:

效果圖

404錯誤

在History mode下题翻,如果直接通過地址欄訪問路徑,那么會出現(xiàn)404錯誤腰鬼,這是因為這是單頁應(yīng)用(廢話)…其實是因為調(diào)用了history.pushState API 所以所有的跳轉(zhuǎn)之類的操作都是通過router來實現(xiàn)的嵌赠,解決這個問題很簡單,只需要在后臺配置如果URL匹配不到任何靜態(tài)資源熄赡,就跳轉(zhuǎn)到默認(rèn)的index.html姜挺。具體配置如下:

Apache

<IfModule mod_rewrite.c>
  RewriteEngine On
  RewriteBase /
  RewriteRule ^index\.html$ - [L]
  RewriteCond %{REQUEST_FILENAME} !-f
  RewriteCond %{REQUEST_FILENAME} !-d
  RewriteRule . /index.html [L]
</IfModule>

nginx

location / {
  try_files $uri $uri/ /index.html;
}

Node.js (Express)

關(guān)于每次點擊鏈接都要刷新頁面的問題

眾所周知,開發(fā)單頁應(yīng)用就是因為那絲般順滑的體驗效果彼硫,如果每次點擊都會刷新頁面…
出現(xiàn)這個的原因是因為使用了window.location來跳轉(zhuǎn)炊豪,只需要使用使用router提供的方法,就能夠解決這個問題:

在main.js中配置中將router綁定到全局

Vue.prototype.router = router;

之后都使用如下的方式來控制跳轉(zhuǎn)

this.router.push('driver/service');

好啦拧篮,這次關(guān)于Vue路由的“坑”就介紹到這里了词渤,以后會發(fā)表更多的優(yōu)質(zhì)文章,如果對你有所幫助串绩,請點擊贊缺虐,謝謝。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末礁凡,一起剝皮案震驚了整個濱河市高氮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌顷牌,老刑警劉巖纫溃,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異韧掩,居然都是意外死亡紊浩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來坊谁,“玉大人费彼,你說我怎么就攤上這事】谏郑” “怎么了箍铲?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長鬓椭。 經(jīng)常有香客問我颠猴,道長,這世上最難降的妖魔是什么小染? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任翘瓮,我火速辦了婚禮,結(jié)果婚禮上裤翩,老公的妹妹穿的比我還像新娘资盅。我一直安慰自己,他們只是感情好踊赠,可當(dāng)我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布呵扛。 她就那樣靜靜地躺著,像睡著了一般筐带。 火紅的嫁衣襯著肌膚如雪今穿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天伦籍,我揣著相機(jī)與錄音荣赶,去河邊找鬼。 笑死鸽斟,一個胖子當(dāng)著我的面吹牛拔创,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播富蓄,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼剩燥,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了立倍?” 一聲冷哼從身側(cè)響起灭红,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎口注,沒想到半個月后变擒,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡寝志,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年娇斑,在試婚紗的時候發(fā)現(xiàn)自己被綠了策添。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡毫缆,死狀恐怖唯竹,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情苦丁,我是刑警寧澤浸颓,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站旺拉,受9級特大地震影響产上,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蛾狗,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一晋涣、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧淘太,春花似錦姻僧、人聲如沸规丽。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽赌莺。三九已至冰抢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間艘狭,已是汗流浹背挎扰。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留巢音,地道東北人遵倦。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像官撼,于是被迫代替她去往敵國和親梧躺。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容