【轉(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中加上你項目名稱就行了,這樣就能夠成功了灾螃。
最后的頁面效果:
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ì)文章,如果對你有所幫助串绩,請點擊贊缺虐,謝謝。