JS中封裝axios來管控api的2種方式
前言:我們在開發(fā)項目的時候,往往要處理大量的接口.并且在測試環(huán)境 開發(fā)環(huán)境 生產(chǎn)環(huán)境使用的接口baseurl都不一樣 這時候如果在開發(fā)環(huán)境完成之后切換每一個接口的baseurl會變的非常的麻煩,(要去每一個發(fā)出請求的頁面都要去修改地址)
所以為了更好的管控這些api,我們需要自己封裝一個axios定義統(tǒng)一的接口baseurl 這樣在環(huán)境的切換的時候更好的管控和修改.話不多說上代碼!!!
自己創(chuàng)建一個api文件夾 即可
import axios from 'axios'
為了處理java字符串問題
import qs from 'qs'
創(chuàng)建一個axios實例 在其中設(shè)置超時時間和響應(yīng)頭
const http = axios.create({
baseURL: process.env.VUE_APP_MOCK_DATA_URL, // api 的 base_url
timeout: 3000,
headers: {
'Content-Type': 'application/json;charset=utf-8'
}
})
/**
* 請求攔截 可以在發(fā)送請求的時候加上判斷信息
*/
http.interceptors.request.use(config => {
*****
return config
}, error => {
return Promise.reject(error)
})
/**
* 響應(yīng)攔截 可以對傳回的數(shù)據(jù)做出判斷
*/
http.interceptors.response.use(response => {
return response
}, error => {
return Promise.reject(error)
})
將這個封裝好的axios 暴露出去
export default http
在main.js中引入并且掛載到原型對象上
import http from '@/api/api.js' Vue.prototype.$http = http
第一種封裝的方式一般就是對于api數(shù)量不是特別多的時候 復(fù)雜層級不高的情況 這樣封裝完全可以
第二種方式
'use strict'
同樣的也需要引入這兩個包
import axios from 'axios'
import qs from 'qs'
// 設(shè)置攔截器 默認(rèn)請求url得前綴
// axios.defaults.baseURL = process.env.NODE_ENV === 'production' ? '/custInfo' :
// '127.0.0.1:8888',
// axios.interceptors.request.use(config => {
// // // loading
// return config
// }, error => {
// return Promise.reject(error)
// })
//
// axios.interceptors.response.use(response => {
// return response
// }, error => {
// return Promise.resolve(error.response)
// })
export default {
post(url, data) {
return new Promise((resolve, reject) => {
axios({
method: 'post',
url,
// qs這個插件主要是為了解決java后臺接受到得參數(shù)必須是字符串
data: qs.stringify(data),
headers: {
'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
}
}).then((res) => {
resolve(res)
}).catch((error) => {
reject(error)
})
})
},
get (url, params) {
return new Promise((resolve, reject) => {
axios({
method: 'get',
url,
params, // get 請求時帶的參數(shù)
}).then((res) => {
resolve(res)
}).catch((error) => {
reject(error)
})
})
}
}
這種封裝好之后,就可以在創(chuàng)建一個文件夾 然后把所有的接口都寫在一起
getCustValue(params) {
return $http.post('/custOverview/getCustValue', params);
},
getTacntrt(params) {
return $http.get('/dict/getTacntrtMgmtMsgMonth', params);
},
query(params) {
return $http.post('/indexManager/queryVipFlowCount', params);
}
然后一一列舉 就可以非常好的梳理api
總結(jié)
以上所述是小編給大家介紹的JS中封裝axios來管控api的2種方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
JavaScript獲取客戶端計算機硬件及系統(tǒng)等信息的方法
本文為大家詳細(xì)介紹下如何使用JavaScript獲取客戶端計算機硬件及系統(tǒng)等信息,下面有個不錯的示例,感興趣的朋友可以參考下2014-01-01
js判斷出兩個字符串最大子串的函數(shù)實現(xiàn)方法
下面小編就為大家?guī)硪黄猨s判斷出兩個字符串最大子串的函數(shù)實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11

