真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Vue路由Historymode模式中頁面無法渲染怎么辦

這篇文章主要為大家展示了“Vue路由History mode模式中頁面無法渲染怎么辦”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue路由History mode模式中頁面無法渲染怎么辦”這篇文章吧。

創(chuàng)新互聯(lián)建站長期為上1000+客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為海安企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),海安網(wǎng)站改版等技術(shù)服務(wù)。擁有十載豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。

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àn)檎麄€(gè)應(yīng)用本身而言就只有一個(gè)HTML,其他的都是通過router來渲染。如果因?yàn)闃I(yè)務(wù)需要,或者單純是覺得帶#號不美觀,那么可以使用history模式,簡單而言就是在router的配置文件index.js中添加如下一行代碼:

history: mode

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

頁面無法渲染

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

sdp.driver.com/driver/

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

sdp.driver.com

這樣的一種形式,沒問題。可是如果配置了模塊,或者放置在了子文件夾下面,那么就會出問題。其實(shí),這是因?yàn)閞outer無法找到路徑中的組件,所以也就無法渲染了。只需要修改router中的index.js,在每個(gè)path中加上你項(xiàng)目名稱就行了,這樣就能夠成功了。

Vue路由History mode模式中頁面無法渲染怎么辦

最后的頁面效果:

Vue路由History mode模式中頁面無法渲染怎么辦

404錯(cuò)誤

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

Apache


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

nginx

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

Node.js (Express)

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

眾所周知,開發(fā)單頁應(yīng)用就是因?yàn)槟墙z般順滑的體驗(yàn)效果,如果每次點(diǎn)擊都會刷新頁面…

出現(xiàn)這個(gè)的原因是因?yàn)槭褂昧藈indow.location來跳轉(zhuǎn),只需要使用使用router提供的方法,就能夠解決這個(gè)問題:

在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)行業(yè)資訊頻道!


分享文章:Vue路由Historymode模式中頁面無法渲染怎么辦
鏈接地址:http://weahome.cn/article/jhcjic.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部