国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

vue開發微信商城項目總結之四--本地代理處理跨域問題

Leck1e / 1450人閱讀

摘要:關于項目的基本描述,參見開發微信商城項目總結之一項目介紹開發微信商城項目總結之二配置開發微信商城項目總結之三根據不同的開發環境做配置之前處理跨域問題是通過,但是只有開發環境是跨域的,代碼打包后上傳到服務器便不再跨域,所以在本地做了判斷,判斷

關于項目的基本描述,參見

vue開發微信商城項目總結之一–項目介紹

vue開發微信商城項目總結之二–Eslint配置

vue開發微信商城項目總結之三–根據不同的開發環境做配置

之前處理跨域問題是通過jsonp,但是只有開發環境是跨域的,代碼打包后上傳到服務器便不再跨域,所以ajax在本地做了判斷,判斷是否是跨域,跨域則走jsonp否則其他正常調用

可以通過本地配置nginx做代理來處理跨域,但是作為一個前端來說,學習成本略高,

后來發現vue-cli中也有代理,解決開發環境跨域的問題,

config>index.js 在dev中找到中找到proxyTable,并對其進行配置,我的index.js如下

var path = require("path")
var new_date = new Date();

/**日期時間格式化 20170413170432**/
var date_month = new_date.getMonth() <= 8 ? "0" + (new_date.getMonth() + 1) : (new_date.getMonth() + 1);
var date_day = new_date.getDate() <= 9 ? "0" + new_date.getDate() : new_date.getDate();
var date_hour = new_date.getHours() <= 9 ? "0" + new_date.getHours() : new_date.getHours();
var date_min = new_date.getMinutes() <= 9 ? "0" + new_date.getMinutes() : new_date.getMinutes();
var date_sec = new_date.getSeconds() <= 9 ? "0" + new_date.getSeconds() : new_date.getSeconds();
var new_dateTime = new_date.getFullYear() + "年" + date_month + "月" + date_day + "日" + date_hour + "時" + date_min + "分" + date_sec + "秒";

module.exports = {
  build: {
    env: require("./prod.env"),
    index: path.resolve(__dirname, "../dist/" + new_dateTime + "app" + "/index.html"), // 編譯輸入的 index.html 文件
    assetsRoot: path.resolve(__dirname, "../dist/" + new_dateTime + "app"), // 編譯輸出的靜態資源路徑
    assetsSubDirectory: "static", // 編譯輸出的二級目錄
    assetsPublicPath: "./", // 編譯發布的根目錄,可配置為資源服務器域名或 CDN 域名
    productionSourceMap: false, // 是否開啟 cssSourceMap
    productionGzip: false, // 是否開啟 gzip
    productionGzipExtensions: ["js", "css"], // 需要使用 gzip 壓縮的文件擴展名
    bundleAnalyzerReport: process.env.npm_config_report
  },
  buildppe: {
    env: require("./ppe.env"),
    index: path.resolve(__dirname, "../dist/" + new_dateTime + "ppe" + "/index.html"), // 編譯輸入的 index.html 文件
    assetsRoot: path.resolve(__dirname, "../dist/" + new_dateTime + "ppe"), // 編譯輸出的靜態資源路徑
    assetsSubDirectory: "static", // 編譯輸出的二級目錄
    assetsPublicPath: "./",// 編譯發布的根目錄,可配置為資源服務器域名或 CDN 域名
    productionSourceMap: false, // 是否開啟 cssSourceMap
    productionGzip: false, // 是否開啟 gzip
    productionGzipExtensions: ["js", "css"], // 需要使用 gzip 壓縮的文件擴展名
    bundleAnalyzerReport: process.env.npm_config_report
  },
  builffffdd: {
    env: require("./ffffd.env"),
    index: path.resolve(__dirname, "../dist/" + new_dateTime + "dev" + "/index.html"), // 編譯輸入的 index.html 文件
    assetsRoot: path.resolve(__dirname, "../dist/" + new_dateTime + "dev"), // 編譯輸出的靜態資源路徑
    assetsSubDirectory: "static", // 編譯輸出的二級目錄
    assetsPublicPath: "./",// 編譯發布的根目錄,可配置為資源服務器域名或 CDN 域名
    productionSourceMap: false, // 是否開啟 cssSourceMap
    productionGzip: false, // 是否開啟 gzip
    productionGzipExtensions: ["js", "css"], // 需要使用 gzip 壓縮的文件擴展名
    bundleAnalyzerReport: process.env.npm_config_report
  },
  dev: {
    env: require("./dev.env"),
    port: 1111,
    autoOpenBrowser: true,
    assetsSubDirectory: "static",
    assetsPublicPath: "/",
    proxyTable: {
      "/baseUrl": { /* 當發生跨域請求是調用此接口 本地代理*/
        target: "https://api.douban.com/v2/event/list?loc=108288&start=1&count=3",
        changeOrigin: true,
        pathRewrite: {
          "^/baseUrl": ""
        }
      },
    },
    cssSourceMap: false
  }
}

在使用的時候

get () { // 開發環境跨域時調用本地代理 具體查看 config-->index.js
      this.$http.post(process.env.baseUrl)
        .then(res => {
          console.log(res)
          this.data = res
        })
    }

config>config>dev.env.js

var merge = require("webpack-merge")
var prodEnv = require("./prod.env")
 
module.exports = merge(prodEnv, {
  NODE_ENV: ""development"",
  baseUrl: ""/baseUrl"",//處理跨域
  /* 福幣商品skuID */
  rechargeList: `[{
    skuid: "020d73154fea407aba111e8a0b010cb1",
    name: "開發",
    thumbPath: ""
  }, {
    skuid: "b7ef02ebab9f4edf9cb44cb184f7dec3",
    name: "開發",
    thumbPath: ""
  }, {
    skuid: "52856479a6e74c4e9ea943ce6b4d4827",
    name: "開發",
    thumbPath: ""
  }, {
    skuid: "a4b821d1bcf34d4b9af286c1a9cedc92",
    name: "開發",
    thumbPath: ""
  }]`,
 
})

process.env 是根據不同的環境調用不同的接口,具體看這里我的項目中一共四個環境

開發環境 dev
測試環境 ffffd
預生產環境 ppe
生產環境(正式環境) production

項目地址在這里

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/88597.html

相關文章

  • vue發微商城項目總結之五--vue實現九宮格抽獎

    摘要:根據產品提出的需求,需要做一個抽獎活動頁面需求簡介九宮格抽獎,中獎概率可配置,以九宮格轉盤的形式進行抽獎,獎品分為三類,實物類獎品,收貨人信息可編輯,默認為登陸用戶,可生成訂單福幣類獎品,直接發放,可在交易明細中查看優惠劵類獎品,交易明細中 根據產品提出的需求,需要做一個抽獎活動頁面 需求簡介 九宮格抽獎,中獎概率可配置,以九宮格轉盤的形式進行抽獎,獎品分為三類, 實物類獎品,收貨人...

    CoorChice 評論0 收藏0
  • vue發微商城項目總結之三--根據不同的發環境做配置

    摘要:項目是基于搭建,項目分為開發環境,測試環境,預生產環境,生產環境,其中開發環境和測試環境調用同一個接口,開發環境調用服務器端的測試接口會跨域,以上需求就引發了一些問題,問題一測試環境包括開發環境,并且開發環境跨域,預生產環境,生產環境,有 項目是基于vue-cli搭建,項目分為開發環境,測試環境,預生產環境,生產環境,其中開發環境和測試環境調用同一個接口,開發環境調用服務器端的測試接口...

    Magicer 評論0 收藏0
  • vue發微商城項目總結之六--關于vuex的思考

    先對項目進行一下簡單的介紹 vue開發微信商城項目總結之一–項目介紹 項目開發初期,由于項目比較著急上線,前端的框架在選型上比較倉促,只是因為vue學習成本較低,就選了它,沒有什么別的原因, 之前看過angular2一段時間,又趁著周末看了兩天vue,就倉促開發,所以埋下了很多坑,項目(項目目前沒有對游客開放,是2B2C的模式)上線后,回頭填坑,發現了很多問題,因為之前一直是基于Jquery模式的...

    PrototypeZ 評論0 收藏0
  • 使用 vue2.0 發微公眾號下前后端分離的SPA站點的填坑之旅

    摘要:目前正在寫一個微信公眾號的小項目,記錄一下遇到的問題和解決方法主要是前端。前端提交時使用,在后端再取出對應的微信支付看了下文檔,以前是需要用喚起支付,而現在則是把微信內置到了微信的瀏覽器中。 目前正在寫一個微信公眾號的小項目,記錄一下遇到的問題和解決方法(主要是前端)。內容持續更新中~ 主要實現 前后端分離前端為 SPA 單頁面使用微信的JSSDK微信支付 技術方案 后端使用 php ...

    afishhhhh 評論0 收藏0
  • 使用 vue2.0 發微公眾號下前后端分離的SPA站點的填坑之旅

    摘要:目前正在寫一個微信公眾號的小項目,記錄一下遇到的問題和解決方法主要是前端。前端提交時使用,在后端再取出對應的微信支付看了下文檔,以前是需要用喚起支付,而現在則是把微信內置到了微信的瀏覽器中。 目前正在寫一個微信公眾號的小項目,記錄一下遇到的問題和解決方法(主要是前端)。內容持續更新中~ 主要實現 前后端分離前端為 SPA 單頁面使用微信的JSSDK微信支付 技術方案 后端使用 php ...

    Taonce 評論0 收藏0

發表評論

0條評論

Leck1e

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<