這篇文章主要為大家展示了“Vue路由History mode模式中頁面無法渲染怎么辦”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue路由History mode模式中頁面無法渲染怎么辦”這篇文章吧。
專注于為中小企業(yè)提供網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)犍為免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上1000家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。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
這樣的一種形式,沒問題??墒侨绻渲昧四K,或者放置在了子文件夾下面,那么就會出問題。其實(shí),這是因為router無法找到路徑中的組件,所以也就無法渲染了。只需要修改router中的index.js,在每個path中加上你項目名稱就行了,這樣就能夠成功了。
最后的頁面效果:
404錯誤
在History mode下,如果直接通過地址欄訪問路徑,那么會出現(xiàn)404錯誤,這是因為這是單頁應(yīng)用(廢話)…其實(shí)是因為調(diào)用了history.pushState API 所以所有的跳轉(zhuǎn)之類的操作都是通過router來實(shí)現(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)于每次點(diǎn)擊鏈接都要刷新頁面的問題
眾所周知,開發(fā)單頁應(yīng)用就是因為那絲般順滑的體驗效果,如果每次點(diǎn)擊都會刷新頁面…
出現(xiàn)這個的原因是因為使用了window.location來跳轉(zhuǎn),只需要使用使用router提供的方法,就能夠解決這個問題:
在main.js中配置中將router綁定到全局
Vue.prototype.router = router;
之后都使用如下的方式來控制跳轉(zhuǎn)
this.router.push('driver/service');
以上是“Vue路由History mode模式中頁面無法渲染怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
本文標(biāo)題:Vue路由Historymode模式中頁面無法渲染怎么辦-創(chuàng)新互聯(lián)
分享地址:http://jinyejixie.com/article10/dipcdo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、網(wǎng)站內(nèi)鏈、商城網(wǎng)站、營銷型網(wǎng)站建設(shè)、網(wǎng)站導(dǎo)航、搜索引擎優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容