溫馨提示×

溫馨提示×

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

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

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

發(fā)布時間:2020-10-23 13:17:42 來源:腳本之家 閱讀:234 作者:HMleilei 欄目:web開發(fā)

使用vue init webpack 你的項目名稱初始化一個vue的項目

  • 安裝依賴 npm install vue-resource http-proxy-middleware vuex koa
  • 在項目的main.js中引入并注冊下載的依賴
  • 在main.js中引入vue-resource并注冊到vue實例中
import VueResource from 'vue-resource' //用來請求接口
Vue.use(VueResource)
//開啟后請求就會以application/x-www-form-urlencoded作為MIME type 就像普通的html表單一樣,form形式傳給后臺,而非JSON
Vue.http.options.emulateJSON = true;

在main.js文件同級創(chuàng)建一個store的文件夾用來存放vuex的文件

在store文件夾中創(chuàng)建一個index.js的文件(vue在查找時會自動查找這個文件),在文件中創(chuàng)建store實例并導出

 import Vue from 'vue'
 import VueX from 'vuex'
 import actions from './actions' //這里為了可擴展性,所以單獨創(chuàng)建一個文件用來存放請求方法
 Vue.use(VueX);
 //請求之甬道actions所以只導入了actions
 export default new VueX.Store({
  actions
 });

在store文件夾中創(chuàng)建一個actions.js的文件用來存放請求方法

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

配置請求代理

在config文件夾下面創(chuàng)建一個host.js文件用來存放開發(fā)、測試、生產(chǎn)的請求地址ip

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

在文件中你可以根據(jù)條件來配置到底是開發(fā)還是測試或者是正式環(huán)境

let HostType = 0; //用來判斷當前是什么環(huán)境
let Host = {}; //用來存儲當前環(huán)境的請求ip
if (HostType == 0) {
 Host = { //對象內(nèi)的字段可以自定義如果整個項目只有一個后臺地址只需要一個字段就可以;
 api: "127.0.0.1:9000",
 base: "",
 fileUp: ""
 } 
} else if (HostType == 1) {
 Host = {
 ...
 }
} else if (HostType == 2) {
 Host = {
 ...
 }
}
 module.exports = Host;

在config文件夾下面創(chuàng)建一個proxy-table.js文件用來存放代理的配置

const HOST = require("./HOST.js");
module.exports = {
 //接口代理
 "/api/text": {
 target: HOST.api, //需要代理到那個地址
 changeOrigin: true //是否跨域
 },
 "/api/demo": {
 target: HOST.api,
 changeOrigin: true
 }
}

在config文件夾下面創(chuàng)建一個proxy-middleware.js憑借代理和注冊

//導入插件
const proxyMiddleware = require("http-proxy-middleware");
//導入代理的配置
const proxyTable = require("./proxy-table");
//拿出配置代理的所有匹配的字段
const proxyContext = Object.keys(proxyTable); // ["/api/text","/api/demo"]

module.exports = () => {
 //創(chuàng)建一個默認的配置對象
 const defautOptions = {
 changeOrigin: true,
 secure: false
 }
 //為什么return的是一個async的方法是因為請求代理是通過服務器進行代理的在啟動腳本中會使用koa框架來注冊這個中間件
 return async (ctx, next) => { //ctx和next都是koa框架中間件自帶的參數(shù)
 for (let context of proxyContext) { //循環(huán)我們拿到的keys數(shù)組
  if (ctx.url.startsWith(context)) { //判斷當前請求的url中是不是以拿到的keys數(shù)組中的某個值開頭的
   ctx.respond = false; //繞開koa框架的內(nèi)置response處理
   let options = proxyTable[context];
  //如果拿取到的直接是IP地址就賦值給配置對象
   if (typeof options === 'string') {
   options = {
    target: options
   }
   }
   //使用Object.assign()方法合并兩個對象
   options = Object.assign({},defautOptions,options);
   //將每一個代理都注冊,這里必須return一個自執(zhí)行函數(shù)否則代理不會設置成功
   proxyMiddleware(context,options)(ctx.req,ctx.res, next);
  }
 }
 await next();
 }
}

在項目的更目錄中創(chuàng)建一個服務啟動的文件腳本名字自定義

//在腳本文件中導入我們需要的框架和代理配置文件
const Koa = require("koa"); //所用的框架
const proxy = require("./config/proxy-middleware"); //剛才創(chuàng)建的代理配置文件
//創(chuàng)建一個服務
const app = new Koa();
//將代理插件注冊到服務上
app.use(proxy()); //因為我們導出的是一個方法所以需要使用調(diào)用的方式注冊
//啟動服務
app.listen(9000,() => {
 console.log("server running at http://127.0.0.1:9000");
});
//對koa框架不是熟悉的可以使用express框架 如果使用express框架拿代理就不用使用前面那樣復雜的寫法了
const express = require("express");
const proxy = require("http-proxy-middleware");
const app = express();
app.use(express.static("dist/"));
app.use("/all", proxy({
 target: "http://127.0.0.1:3000",
 changeOrigin: true,
}))
app.listen(9000, (err) => {
 if (err) return console.log(err);
 console.log("app as running at http://127.0.0.1:9000");
})

代理配置好以后就可以寫請求方法了,在創(chuàng)建好的store文件夾下面的actions文件里編寫請方法

//導入Vue
import Vue from "vue"
export default {
 //測試接口
 testInterface({},postdata) {
  //postdata是你調(diào)用的時候傳過來的參數(shù)可以更具需求拼接接口
  //let ipstr = `/api/text?id=${postdata.id}`;
  //return Vue.http.get(ipstr,{}).then(response => {
  return Vue.http.get("/api/text",{}).then(response => {
  if (response.status == 200) {
   return new Promise(response.body);
  } else {
   return new Promise(response.data.message);
  }
  })
 }
}

測試代理是否成功

<div id="app">
 <button @click="clickF">按鈕</button>
</div> 


首先在script標簽里面將vuex導入進來

import {mapActions} from "vuex";

在methods中創(chuàng)建一個方法用來發(fā)送請求,并在methods的最下面使用結(jié)構函數(shù)將我們存在vuex中的請求方法按需導入

methods: {
  clickF() {
   this.testInterface().then(data=> {
    console.log(data);
   })
  },
  ...mapActions(["testInterface"])
 }

直接使用this.方法名就可以訪問到vuex中的actions方法;這里使用的是輔助函數(shù),也可以使用原始方法

在終端中使用node 啟動腳本文件的名稱 或者使用 nodemon 啟動腳本文件的名稱

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

在瀏覽器中打開服務的地址點擊我們創(chuàng)建的按鈕查看請求接口

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

可以看到我們的代理是請求成功的;狀態(tài)之所以是304是因為第二次請求的時候如果請求沒有發(fā)生改變就會使用瀏覽器緩存;

上面遺留了一個bug就是這個方法只適用于build后的項目;在開發(fā)中每次都build無疑浪費了很多時間,下面就來在開發(fā)環(huán)境中使用服務器代理的方式完成跨域請求

如果是cli創(chuàng)建的項目直接在config文件夾下面的index文件中的proxyTable進行添加就可以了

Vue使用vue-recoure + http-proxy-middleware + vuex配合promise實現(xiàn)基本的跨域請求封裝

向AI問一下細節(jié)

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

AI