詳解Vue路由History mode模式中頁(yè)面無(wú)法渲染的原因及解決
Vue下路由History mode導(dǎo)致頁(yè)面無(wú)法渲染的原因
用 Vue.js + vue-router 創(chuàng)建單頁(yè)應(yīng)用,是非常簡(jiǎn)單的。使用 Vue.js ,我們已經(jīng)可以通過(guò)組合組件來(lái)組成應(yīng)用程序,當(dāng)你要把 vue-router 添加進(jìn)來(lái),我們需要做的是,將組件(components)映射到路由(routes),然后告訴 vue-router 在哪里渲染它們。
一般開(kāi)發(fā)的單頁(yè)應(yīng)用的URL都會(huì)帶有#號(hào)的hash模式,因?yàn)檎麄€(gè)應(yīng)用本身而言就只有一個(gè)HTML,其他的都是通過(guò)router來(lái)渲染。如果因?yàn)闃I(yè)務(wù)需要,或者單純是覺(jué)得帶#號(hào)不美觀,那么可以使用history模式,簡(jiǎn)單而言就是在router的配置文件index.js中添加如下一行代碼:
history: mode
沒(méi)錯(cuò),這樣URL不再會(huì)有#號(hào),你會(huì)發(fā)現(xiàn)整個(gè)地址欄回到了你熟悉的那個(gè)樣子,不過(guò),接下來(lái)介紹的就非常的重要了,可能很多剛?cè)腴T(mén)的新人或多或少都會(huì)遇見(jiàn)這么一兩個(gè)坑…
頁(yè)面無(wú)法渲染
這里以我寫(xiě)的一個(gè)項(xiàng)目為例子,當(dāng)我開(kāi)啟history模式的時(shí)候,我并沒(méi)有對(duì)路由進(jìn)行任何處理,在Dev階段一切都是正常的,可是打包之后,訪問(wèn)項(xiàng)目路徑:
sdp.driver.com/driver/
會(huì)發(fā)現(xiàn)頁(yè)面一片空白,但是靜態(tài)文件都能夠正常的引用,因?yàn)槭褂昧薡II中的模塊,所以除了域名之外,還會(huì)帶有driver模塊名。一般很多人創(chuàng)建的項(xiàng)目都放在了根目錄下面,也就是:
sdp.driver.com
這樣的一種形式,沒(méi)問(wèn)題??墒侨绻渲昧四K,或者放置在了子文件夾下面,那么就會(huì)出問(wèn)題。其實(shí),這是因?yàn)閞outer無(wú)法找到路徑中的組件,所以也就無(wú)法渲染了。只需要修改router中的index.js,在每個(gè)path中加上你項(xiàng)目名稱就行了,這樣就能夠成功了。

最后的頁(yè)面效果:

404錯(cuò)誤
在History mode下,如果直接通過(guò)地址欄訪問(wèn)路徑,那么會(huì)出現(xiàn)404錯(cuò)誤,這是因?yàn)檫@是單頁(yè)應(yīng)用(廢話)…其實(shí)是因?yàn)檎{(diào)用了history.pushState API 所以所有的跳轉(zhuǎn)之類的操作都是通過(guò)router來(lái)實(shí)現(xiàn)的,解決這個(gè)問(wèn)題很簡(jiǎn)單,只需要在后臺(tái)配置如果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)于每次點(diǎn)擊鏈接都要刷新頁(yè)面的問(wèn)題
眾所周知,開(kāi)發(fā)單頁(yè)應(yīng)用就是因?yàn)槟墙z般順滑的體驗(yàn)效果,如果每次點(diǎn)擊都會(huì)刷新頁(yè)面…
出現(xiàn)這個(gè)的原因是因?yàn)槭褂昧藈indow.location來(lái)跳轉(zhuǎn),只需要使用使用router提供的方法,就能夠解決這個(gè)問(wèn)題:
在main.js中配置中將router綁定到全局
Vue.prototype.router = router;
之后都使用如下的方式來(lái)控制跳轉(zhuǎn)
this.router.push('driver/service');
好啦,這次關(guān)于Vue路由的“坑”就介紹到這里了,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 針對(duì)Vue路由history模式下Nginx后臺(tái)配置操作
- vue多頁(yè)面項(xiàng)目中路由使用history模式的方法
- vue-router路由模式詳解(小結(jié))
- VUE的history模式下除了index外其他路由404報(bào)錯(cuò)解決辦法
- vue2.0 路由模式mode="history"的作用
- Vue路由history模式解決404問(wèn)題的幾種方法
- Vue下路由History模式打包后頁(yè)面空白的解決方法
- 3種vue路由傳參的基本模式
- vue router嵌套路由在history模式下刷新無(wú)法渲染頁(yè)面問(wèn)題的解決方法
- vue 基于abstract 路由模式 實(shí)現(xiàn)頁(yè)面內(nèi)嵌的示例代碼
相關(guān)文章
優(yōu)選七個(gè)用于vue開(kāi)發(fā)的JS庫(kù)
這篇文章主要介紹了JavaScript優(yōu)選七個(gè)用于vue開(kāi)發(fā)庫(kù),借助開(kāi)源庫(kù)加速Vue項(xiàng)目的開(kāi)發(fā)進(jìn)度是現(xiàn)代前端開(kāi)發(fā)比較常見(jiàn)的方式,平常收集一些JavaScript庫(kù)介紹,在遇到需要的時(shí)候可以信手拈來(lái)2023-02-02
Composition Api封裝業(yè)務(wù)hook思路示例分享
這篇文章主要為大家介紹了Composition Api封裝業(yè)務(wù)hook的思路示例分享,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
vue elementUI el-form 數(shù)據(jù)無(wú)法賦值且不報(bào)錯(cuò)的問(wèn)題及解決方法
vue項(xiàng)目中使用elementUI的el-form組件,里面有部分后端數(shù)據(jù)遍歷的字段和部分確定的字段,遇到個(gè)問(wèn)題遍歷的字段可以修改值但是確定的幾個(gè)字段無(wú)法修改值,下面小編給大家分享vue elementUI el-form 數(shù)據(jù)無(wú)法賦值且不報(bào)錯(cuò)的問(wèn)題及解決方法,感興趣的朋友一起看看吧2023-12-12
postcss-pxtorem設(shè)置不轉(zhuǎn)換UI框架的CSS單位問(wèn)題
這篇文章主要介紹了postcss-pxtorem設(shè)置不轉(zhuǎn)換UI框架的CSS單位問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
vue elementUI select下拉框設(shè)置默認(rèn)值(賦值)失敗的解決
這篇文章主要介紹了vue elementUI select下拉框設(shè)置默認(rèn)值(賦值)失敗的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
如何用vue3+Element?plus實(shí)現(xiàn)一個(gè)完整登錄功能
要實(shí)現(xiàn)用戶的登錄功能,可以使用Vue3和Element?Plus,下面這篇文章主要給大家介紹了關(guān)于如何基于Vue3和Element?Plus組件庫(kù)實(shí)現(xiàn)一個(gè)完整的登錄功能,文中提供了詳細(xì)的代碼示例,需要的朋友可以參考下2023-10-10
vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況
這篇文章主要介紹了vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11

