91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解Vue項目部署遇到的問題及解決方案

發布時間:2020-09-07 05:06:02 來源:腳本之家 閱讀:207 作者:文博 欄目:web開發

寫在前面

Vue-Router 有兩種模式,默認是 hash 模式,另外一種是 history 模式。

  • hash:也就是地址欄里的 # 符號。比如 http://www.example/#/hello,hash 的值為 #/hello。特點:hash 雖然出現 URL 中,但不會被包含在 HTTP 請求中,對后端不會產生什么影響,改變 URL 不會重載頁面。
  • history:利用了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法,來完成 URL 跳轉而無須重新加載頁面。(需要特定瀏覽器支持)

hash 和 history 兩種模式都是基于瀏覽器自身的屬性,vue-router 只是利用了這兩個特性(底層還是瀏覽器提供的接口)來實現前端路由。

使用場景

一般來說,兩種模式都是可以的。除非在意不太漂亮的 #,只能選擇 history。

這兩種模式在開發環境下都沒有什么太大的問題,但是當部署到生產環境中后,兩者有所不同。

hash 模式部署沒有什么問題,只要訪問到服務器上的 index.html,就可以訪問網站了。
history 模式下,前端的 URL 必須和實際向后端發起請求的 URL 一致,如 http://www.example.com/user/id。如果后端缺少對 /user/id 的路由處理,將返回 404 錯誤。

不過這種模式要玩好,還需要后臺配置支持……所以呢,你要在服務端增加一個覆蓋所有情況的候選資源:如果 URL 匹配不到任何靜態資源,則應該返回同一個 index.html 頁面,這個頁面就是你 app 依賴的頁面。- Vue-Router

問題起因

在做「年度賬單」項目的時候,項目部署的時候,用的是 hash 模式。APP安卓端分享出去的鏈接對于 # 做了特殊處理,encode 轉義成了 %23,所以路由只能換成 history 的模式。

因此,現把解決的思路總結下,雖然 官網 上給出了解決方案,但在實際的編碼中也遇到了一些問題。

根目錄下

當項目在根目錄下部署的時候(如 http://www.example.com/),vue 的相關文件默認不需要修改,修改的是后端,這里以 nginx 為例。

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

$uri 就是訪問的 url,不包含 域名 和 querystring。例如 /test/hello 當訪問 $uri 時,如果存在,則訪問 $uri/, 不存在就訪問 /index.html 這樣配置好,訪問 http://example.com/ 時就可以訪問到網站了,進入多級目錄后刷新頁面也不會存在問題。

子級目錄下

這里涉及到修改 vue 項目幾個配置文件。

先定義幾個環境

  • 部署的域名:http://www.example.com:8080/
  • nginx 的 root 目錄:home/web/
  • vue 的部署路徑:home/web/h6-year-bill/
  • vue 項目的鏈接:http://www.example/h6-year-bill/
  • vue 項目的靜態資源路徑:http://www.example/h6-year-bill/static/

1. 打包后的靜態資源路徑需要修改

找到 build/config/index.js,代碼如下:

...
build: {
...
- assetsPublicPath
  // 訪問路徑,修改成絕對路徑
+ assetsPublicPath: '/h6-year-bill/'
}

2. 路由文件

Vue-Router 有一個 base 屬性, 傳送門

base
類型: string
默認值: "/"
應用的基路徑。例如,如果整個單頁應用服務在 /app/ 下,然后 base 就應該設為 "/app/"

因此,找到 src/router/index.js,代碼如下:

// 不影響本地開發,兼容性做了處理
const isHistoryMode = process.env.NODE_ENV === 'production' ? {
 mode: 'history',
 base: '/h6-year-bill/'
} : {
 mode: 'hash'
};

const router = new Router({
 ...isHistoryMode,
 routes
});

至此,打包配置的相關修改已全部完成,項目也能夠正常訪問。

但還是會有一個問題,跳轉到某個路由后,刷新頁面,就會出現頁面空白,或者路由不通,此時就要修改 nginx 的配置了。

3. nginx 配置相關修改

nginx部署路徑/conf/nginx.conf,修改如下:

#h6-year-bill
location ^~ /h6-year-bill {
 root /home/web;
 index index.html;
 try_files $uri $uri/ /h6-year-bill/index.html last;
}

/h6-year-bill/ 就是部署的網站目錄。

這樣幾項配置后,就可以在子目錄下訪問網站,刷新也沒有問題。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

阿拉尔市| 景洪市| 临高县| 怀安县| 咸宁市| 嵩明县| 舟山市| 什邡市| 治县。| 龙山县| 宕昌县| 南充市| 西林县| 金溪县| 个旧市| 永修县| 汝城县| 闸北区| 徐汇区| 连江县| 彰武县| 新沂市| 伊宁县| 长海县| 东丰县| 邵武市| 盱眙县| 东港市| 江城| 高尔夫| 赤城县| 柯坪县| 兴仁县| 九江县| 富锦市| 忻城县| 德阳市| 永泰县| 苏尼特右旗| 温州市| 兴宁市|