溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶(hù)服務(wù)條款》

Vue路由History mode模式中頁(yè)面無(wú)法渲染如何解決

發(fā)布時(shí)間:2022-11-09 09:47:27 來(lái)源:億速云 閱讀:138 作者:iii 欄目:開(kāi)發(fā)技術(shù)

本篇內(nèi)容主要講解“Vue路由History mode模式中頁(yè)面無(wú)法渲染如何解決”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“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)不美觀(guān),那么可以使用history模式,簡(jiǎn)單而言就是在router的配置文件index.js中添加如下一行代碼:

history: mode

沒(méi)錯(cuò),這樣URL不再會(huì)有#號(hào),你會(huì)發(fā)現(xiàn)整個(gè)地址欄回到了你熟悉的那個(gè)樣子

頁(yè)面無(wú)法渲染

這里以我寫(xiě)的一個(gè)項(xiàng)目為例子,當(dāng)我開(kāi)啟history模式的時(shí)候,我并沒(méi)有對(duì)路由進(jìn)行任何處理,在Dev階段一切都是正常的,可是打包之后,訪(fǎng)問(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)目名稱(chēng)就行了,這樣就能夠成功了。

Vue路由History mode模式中頁(yè)面無(wú)法渲染如何解決

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

Vue路由History mode模式中頁(yè)面無(wú)法渲染如何解決

404錯(cuò)誤

在History mode下,如果直接通過(guò)地址欄訪(fǎng)問(wèn)路徑,那么會(huì)出現(xiàn)404錯(cuò)誤,這是因?yàn)檫@是單頁(yè)應(yīng)用(廢話(huà))…其實(shí)是因?yàn)檎{(diào)用了history.pushState API 所以所有的跳轉(zhuǎn)之類(lèi)的操作都是通過(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');

為什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護(hù)性和可測(cè)試性更強(qiáng)的代碼庫(kù),Vue允許可以將一個(gè)網(wǎng)頁(yè)分割成可復(fù)用的組件,每個(gè)組件都包含屬于自己的HTML、CSS、JavaScript,以用來(lái)渲染網(wǎng)頁(yè)中相應(yīng)的地方,所以越來(lái)越多的前端開(kāi)發(fā)者使用vue。

到此,相信大家對(duì)“Vue路由History mode模式中頁(yè)面無(wú)法渲染如何解決”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢(xún),關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI