亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue項(xiàng)目部署遇到的問(wèn)題及解決方案

 更新時(shí)間:2019年01月11日 10:20:13   作者:文博  
這篇文章主要介紹了詳解Vue項(xiàng)目部署遇到的問(wèn)題及解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

寫在前面

Vue-Router 有兩種模式,默認(rèn)是 hash 模式,另外一種是 history 模式。

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

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

使用場(chǎng)景

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

這兩種模式在開(kāi)發(fā)環(huán)境下都沒(méi)有什么太大的問(wèn)題,但是當(dāng)部署到生產(chǎn)環(huán)境中后,兩者有所不同。

hash 模式部署沒(méi)有什么問(wèn)題,只要訪問(wèn)到服務(wù)器上的 index.html,就可以訪問(wèn)網(wǎng)站了。
history 模式下,前端的 URL 必須和實(shí)際向后端發(fā)起請(qǐng)求的 URL 一致,如 http://www.example.com/user/id。如果后端缺少對(duì) /user/id 的路由處理,將返回 404 錯(cuò)誤。

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

問(wèn)題起因

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

因此,現(xiàn)把解決的思路總結(jié)下,雖然 官網(wǎng) 上給出了解決方案,但在實(shí)際的編碼中也遇到了一些問(wèn)題。

根目錄下

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

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

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

子級(jí)目錄下

這里涉及到修改 vue 項(xiàng)目幾個(gè)配置文件。

先定義幾個(gè)環(huán)境

  • 部署的域名:http://www.example.com:8080/
  • nginx 的 root 目錄:home/web/
  • vue 的部署路徑:home/web/h5-year-bill/
  • vue 項(xiàng)目的鏈接:http://www.example/h5-year-bill/
  • vue 項(xiàng)目的靜態(tài)資源路徑:http://www.example/h5-year-bill/static/

1. 打包后的靜態(tài)資源路徑需要修改

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

...
build: {
...
- assetsPublicPath
  // 訪問(wèn)路徑,修改成絕對(duì)路徑
+ assetsPublicPath: '/h5-year-bill/'
}

2. 路由文件

Vue-Router 有一個(gè) base 屬性, 傳送門

base
類型: string
默認(rèn)值: "/"
應(yīng)用的基路徑。例如,如果整個(gè)單頁(yè)應(yīng)用服務(wù)在 /app/ 下,然后 base 就應(yīng)該設(shè)為 "/app/"

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

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

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

至此,打包配置的相關(guān)修改已全部完成,項(xiàng)目也能夠正常訪問(wèn)。

但還是會(huì)有一個(gè)問(wèn)題,跳轉(zhuǎn)到某個(gè)路由后,刷新頁(yè)面,就會(huì)出現(xiàn)頁(yè)面空白,或者路由不通,此時(shí)就要修改 nginx 的配置了。

3. nginx 配置相關(guān)修改

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

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

/h5-year-bill/ 就是部署的網(wǎng)站目錄。

這樣幾項(xiàng)配置后,就可以在子目錄下訪問(wèn)網(wǎng)站,刷新也沒(méi)有問(wèn)題。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue3+Naive?UI數(shù)據(jù)表格基本使用方式詳解

    vue3+Naive?UI數(shù)據(jù)表格基本使用方式詳解

    這篇文章主要給大家介紹了關(guān)于vue3+Naive?UI數(shù)據(jù)表格基本使用方式詳?shù)南嚓P(guān)資料,Naive?UI是一個(gè)基于Typescript開(kāi)發(fā)的針對(duì)Vue3開(kāi)發(fā)的UI組件庫(kù),由TuSimple(圖森未來(lái))公司開(kāi)發(fā)并開(kāi)源,需要的朋友可以參考下
    2023-08-08
  • Vue3如何使用Vue-Router進(jìn)行路由控制

    Vue3如何使用Vue-Router進(jìn)行路由控制

    無(wú)論是小型項(xiàng)目還是中大型項(xiàng)目,Vue-Router都是必選的一個(gè)組件,Vue-Router提供了便捷的方式進(jìn)行路由跳轉(zhuǎn),在使用過(guò)程中有一些坑,希望能給在編碼找不到問(wèn)題時(shí)的碼農(nóng)提供一點(diǎn)靈感
    2022-06-06
  • Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)層級(jí)結(jié)構(gòu)與用法示例

    Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)

    最近在使用Element開(kāi)發(fā)時(shí)遇到了不少問(wèn)題,下面這篇文章主要給大家介紹了關(guān)于Element?ui中menu組件(el-menu/el-menu-item/el-submenu/template)層級(jí)結(jié)構(gòu)與用法的相關(guān)資料,需要的朋友可以參考下
    2022-12-12
  • VUE-cli3使用 svg-sprite-loader

    VUE-cli3使用 svg-sprite-loader

    svg-sprite-loader 的插件,用來(lái)根據(jù)導(dǎo)入的 svg 文件自動(dòng)生成 symbol 標(biāo)簽并插入 html,這篇文章主要介紹了VUE-cli3使用 svg-sprite-loader,需要的朋友可以參考下
    2018-10-10
  • vue基礎(chǔ)ESLint?Prettier配置教程詳解

    vue基礎(chǔ)ESLint?Prettier配置教程詳解

    這篇文章主要介紹了vue基礎(chǔ)ESLint?Prettier配置教程詳解,本文使用VsCode?+?Vue?+?ESLint?+?Prettier?實(shí)現(xiàn)代碼格式規(guī)范?+?保存自動(dòng)修復(fù)代碼js+vue
    2022-07-07
  • vue添加class樣式實(shí)例講解

    vue添加class樣式實(shí)例講解

    在本文里我們給大家整理了關(guān)于vue添加class樣式實(shí)例,對(duì)此有興趣的朋友們可以學(xué)習(xí)參考下。
    2019-02-02
  • ant-design-vue 實(shí)現(xiàn)表格內(nèi)部字段驗(yàn)證功能

    ant-design-vue 實(shí)現(xiàn)表格內(nèi)部字段驗(yàn)證功能

    這篇文章主要介紹了ant-design-vue 實(shí)現(xiàn)表格內(nèi)部字段驗(yàn)證功能,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-12-12
  • 淺談vue中document.getElementById()拿到的是原值的問(wèn)題

    淺談vue中document.getElementById()拿到的是原值的問(wèn)題

    這篇文章主要介紹了淺談vue中document.getElementById()拿到的是原值的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • vue如何調(diào)用瀏覽器分享功能詳解

    vue如何調(diào)用瀏覽器分享功能詳解

    這篇文章主要給大家介紹了關(guān)于vue如何調(diào)用瀏覽器分享的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • vue中el-table和jsplumb實(shí)現(xiàn)連線功能

    vue中el-table和jsplumb實(shí)現(xiàn)連線功能

    本文主要介紹了el-table和jsplumb實(shí)現(xiàn)連線功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07

最新評(píng)論