首頁 >web前端 >js教程 >如何解決Vue路由History mode模式中頁面無法渲染

如何解決Vue路由History mode模式中頁面無法渲染

不言
不言原創
2018-06-30 17:34:212479瀏覽

這篇文章主要介紹了詳解Vue路由History mode模式中頁面無法渲染的原因及解決,非常具有實用價值,需要的朋友可以參考下

Vue下路由History mode導致頁面無法渲染的原因

用Vue.js vue-router 建立單頁應用,是非常簡單的。使用Vue.js ,我們已經可以透過組合元件來組成應用程序,當你要把vue-router 加入進來,我們需要做的是,將元件(components)對應到路由(routes),然後告訴vue-router 在哪裡渲染它們。

一般開發的單頁應用的URL都會帶有#號的hash模式,因為整個應用程式本身而言就只有一個HTML,其他的都是透過router來渲染。如果因為業務需要,或者單純是覺得帶#號不美觀,那麼可以使用history模式,簡單而言就是在router的配置文件如何解決Vue路由History mode模式中頁面無法渲染中添加如下一行代碼:

history: mode

沒錯,這樣URL不再會有#號,你會發現整個網址列回到了你熟悉的那個樣子,不過,接下來介紹的就非常的重要了,可能很多剛入門的新人或多或少都會遇見這麼一兩個坑…

頁面無法渲染

這裡以我寫的一個項目為例子,當我開啟history模式的時候,我並沒有對路由進行任何處理,在Dev階段一切都是正常的,可是打包之後,訪問專案路徑:

sdp.driver.com/driver/

會發現頁面一片空白,但是靜態檔案都能夠正常的引用,因為使用了YII中的模組,所以除了網域之外,還會帶有driver模組名。一般很多人創建的專案都放在根目錄下面,也就是:

sdp.driver.com

這樣的一種形式,沒問題。可是如果配置了模組,或是放置在了子資料夾下面,那麼就會出問題。其實,這是因為router無法找到路徑中的元件,所以也無法渲染了。只要修改router中的如何解決Vue路由History mode模式中頁面無法渲染,在每個path加上你專案名稱就行了,這樣就能夠成功了。

如何解決Vue路由History mode模式中頁面無法渲染

最後的頁面效果:

如何解決Vue路由History mode模式中頁面無法渲染

404錯誤

在History mode下,如果直接透過網址列存取路徑,那麼會出現404錯誤,這是因為這是單頁應用(廢話)…其實是因為呼叫了history.pushState API 所以所有的跳轉之類的操作都是透過router來實現的,解決這個問題很簡單,只需要在後台配置如果URL匹配不到任何靜態資源,就跳到預設的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)

關於每次點擊連結都要刷新頁面的問題

眾所周知,開發單頁應用程式就是因為那絲般順滑的體驗效果,如果每次點擊都會刷新頁面…

#出現這個的原因是因為使用了window.location來跳轉,只需要使用使用router提供的方法,就能夠解決這個問題:

在main.js中配置中將router綁定到全局

Vue.prototype.router = router;

之後都使用如下的方式來控制跳轉

this.router.push(&#39;driver/service&#39;);

以上就是本文的全部內容,希望對大家的學習有所幫助,更多相關內容請關注PHP中文網!

相關推薦:

VueJS元件之間透過props互動及驗證的方式

如何解決父元件中vuex方法更新state子元件不能及時更新並渲染

以上是如何解決Vue路由History mode模式中頁面無法渲染的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn