1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

      RELATEED CONSULTING
      相關咨詢
      選擇下列產(chǎn)品馬上在線溝通
      服務時間:8:30-17:00
      你可能遇到了下面的問題
      關閉右側工具欄

      新聞中心

      這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
      詳解Vue項目部署遇到的問題及解決方案

      寫在前面

      創(chuàng)新互聯(lián)建站是專業(yè)的柞水網(wǎng)站建設公司,柞水接單;提供成都網(wǎng)站設計、成都網(wǎng)站建設、外貿(mào)網(wǎng)站建設,網(wǎng)頁設計,網(wǎng)站設計,建網(wǎng)站,PHP網(wǎng)站建設等專業(yè)做網(wǎng)站服務;采用PHP框架,可快速的進行柞水網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!

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

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

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

      使用場景

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

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

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

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

      問題起因

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

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

      根目錄下

      當項目在根目錄下部署的時候(如 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/ 時就可以訪問到網(wǎng)站了,進入多級目錄后刷新頁面也不會存在問題。

      子級目錄下

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

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

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

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

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

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

      2. 路由文件

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

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

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

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

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

      但還是會有一個問題,跳轉(zhuǎn)到某個路由后,刷新頁面,就會出現(xiàn)頁面空白,或者路由不通,此時就要修改 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/ 就是部署的網(wǎng)站目錄。

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

      以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。


      網(wǎng)站欄目:詳解Vue項目部署遇到的問題及解決方案
      本文鏈接:http://www.ef60e0e.cn/article/pedgih.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        东丽区| 芷江| 皋兰县| 镇康县| 叙永县| 乌拉特中旗| 罗平县| 高雄市| 满洲里市| 黄山市| 余庆县| 普格县| 南木林县| 瓮安县| 朔州市| 青岛市| 页游| 徐汇区| 天峨县| 敖汉旗| 宣汉县| 丽江市| 油尖旺区| 龙里县| 镇赉县| 沂水县| 沅陵县| 昌图县| 麻阳| 泗洪县| 磴口县| 根河市| 昌图县| 湘潭县| 策勒县| 青河县| 富宁县| 扎鲁特旗| 安庆市| 深泽县| 濮阳县|