基于axios封裝fetch方法及調(diào)用實(shí)例
基礎(chǔ)axios用法請(qǐng)看axios官網(wǎng)
//依賴于axios對(duì)私有ajax進(jìn)行修改
import Qs from 'qs'
import axios from 'axios'
import router from 'router/index'
import {errorPrompt, loading, closeLoading} from 'util/util'
export const status = {
SUCCESS: '100',
NET_ERR: '101', // 網(wǎng)絡(luò)連接異常,請(qǐng)稍候再試
BIZ_ERR: '103', // 業(yè)務(wù)請(qǐng)求異常
NO_AUTH: '104'
}
export function fetch(options) {
return new Promise((resolve, reject) => {
let instance = axios.create({
baseURL: process.env.BASE_API,
timeout: 2000,
headers: {
// "tracecode": window.encodeURIComponent(JSON.stringify({"ua":"","cv":"20161230","token":"3dwo0onUUsPKVJcP8tk","os":"windows10","app":"kind","ws":"1*1","pkey":"f8caf7d7-a5d4-4710-b06f-28a922b6a467"}))
"tracecode": commonBizHeader(isManager(options)),
'Content-Type': 'application/x-www-form-urlencoded'
},
transformRequest: [function (data) {
// Do whatever you want to transform the data
let ret = ''
for (let it in data) {
ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
}
return ret
}]
});
instance.interceptors.request.use(function (response) {
// 請(qǐng)求攔截
loading();
return response;
}, function (error) {
console.log('error 請(qǐng)求攔截 : ', error)
return Promise.reject(error);
});
instance(options)
.then(response => {
const res = response.data;
if (res.errorCode != status.SUCCESS) {
switch (res.errorCode) {
case status.NET_ERR: {
errorPrompt(res.errorMsg)
reject(res)
break;
}
case status.BIZ_ERR: {
errorPrompt(res.errorMsg)
reject(res)
break;
}
case status.NO_AUTH: {
errorPrompt(res.errorMsg)
let session = require("storejs")
if (isManager(options)) { // 管理端
session.remove("managerUserToken")
router.push({path: '/manager/login'})
} else {
session.remove("clientUserToken")
router.push({path: '/client/login'})
}
reject(res)
break
}
}
}
closeLoading();
resolve(res);
}).catch(error => {
closeLoading();
errorPrompt('網(wǎng)絡(luò)連接錯(cuò)誤,請(qǐng)檢查您的網(wǎng)絡(luò)')
console.log('error', error); // for debug
reject(error);
});
});
}
function commonBizHeader (isManager) {
let session = require("storejs");
let params = {}
params['ua'] = window.navigator.userAgent.toLowerCase()
params['cv'] = '123456'
params['ws'] = window.screen.height + '*' + window.screen.width
params['token'] = "123456"
params['os'] = window.navigator.appCodeName
if (isManager) {
params['token'] = session.get('managerUserToken') // 管理 - 用戶令牌
} else {
params['token'] = session.get('clientUserToken') // 用戶 - 用戶令牌
}
params['app'] = 'kind'
let UUID = session.get('pkey')
if (!UUID) {
UUID = getUUID()
window.localStorage.setItem('pkey', UUID)
}
return encodeURIComponent(JSON.stringify(params))
}
function isManager(options) {
return options && options.url && options.url.indexOf("/api/worker") != -1
}
/**
* 獲取UUID
* @returns {string}
*/
export function getUUID() {
let len = 32 // 32長(zhǎng)度
let radix = 16 // 16進(jìn)制
let chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz'.split('')
let uuid = []
let i
radix = radix || chars.length
if (len) {
for (i = 0; i < len; i++) {
uuid[i] = chars[0 | Math.random() * radix]
}
} else {
var r
uuid[8] = uuid[13] = uuid[18] = uuid[23] = '-'
uuid[14] = '4'
for (i = 0; i < 36; i++) {
if (!uuid[i]) {
r = 0 | Math.random() * 16
uuid[i] = chars[(i === 19) ? (r & 0x3) | 0x8 : r]
}
}
}
return uuid.join('').toLowerCase()
}
這是在vue的項(xiàng)目中:在api中調(diào)用方法如下(react剛開始學(xué),還在做簡(jiǎn)單demo)
import {fetch} from 'api/fetch'
export const callAuthCode = (userPhone) => {
return fetch({
url: '/api/auth/code',
method: 'post',
data: ({
userPhone: userPhone,
}),
})
}
因?yàn)槲覀冞@邊的后臺(tái)要求嚴(yán)格區(qū)分get/post請(qǐng)求,所以封裝的方法調(diào)用中必須帶有method,如后臺(tái)已經(jīng)處理好,全部可進(jìn)行post請(qǐng)求,則可以參照axios官網(wǎng)里面將方法全部改為.post
關(guān)于fetch方法的說明:主要進(jìn)行封裝了請(qǐng)求攔截,響應(yīng)攔截,默認(rèn)請(qǐng)求體由json格式轉(zhuǎn)換form格式,當(dāng)然,這些都是在axios官網(wǎng)里可以找到的,不過是集合下了而已
關(guān)于請(qǐng)求頭部分請(qǐng)不要直接套用,這是我們這邊后臺(tái)要求特殊配置的,后臺(tái)接口三端共用,必須區(qū)分是哪里在調(diào)用
以上這篇基于axios封裝fetch方法及調(diào)用實(shí)例就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
如何使用vue slot創(chuàng)建一個(gè)模態(tài)框的實(shí)例代碼
這篇文章主要介紹了如何使用vue slot創(chuàng)建一個(gè)模態(tài)框,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
快速解決vue在ios端下點(diǎn)擊響應(yīng)延時(shí)的問題
今天小編就為大家分享一篇快速解決vue在ios端下點(diǎn)擊響應(yīng)延時(shí)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue組件間通信方法總結(jié)(父子組件、兄弟組件及祖先后代組件間)
這篇文章主要給大家介紹了關(guān)于Vue組件間通信的相關(guān)資料,其中包括父子組件、兄弟組件及祖先后代組件間的通信,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
如何使用Vue3設(shè)計(jì)實(shí)現(xiàn)一個(gè)Model組件淺析
v-model在Vue里面是一個(gè)語法糖,數(shù)據(jù)的雙向綁定,本質(zhì)上還是通過 自定義標(biāo)簽的attribute傳遞和接受,下面這篇文章主要給大家介紹了關(guān)于如何使用Vue3設(shè)計(jì)實(shí)現(xiàn)一個(gè)Model組件的相關(guān)資料,需要的朋友可以參考下2022-08-08
vuex存儲(chǔ)數(shù)據(jù)的幾種方法實(shí)例詳解
在瀏覽網(wǎng)頁時(shí)我們有些時(shí)候需要記住一些用戶選擇的信息,比如登陸時(shí)我們?nèi)绻x擇了記住密碼,那么我們下次進(jìn)入該網(wǎng)頁時(shí)就會(huì)有你上次的登陸信息,下面這篇文章主要給大家介紹了關(guān)于vuex存儲(chǔ)數(shù)據(jù)的幾種方法,需要的朋友可以參考下2022-10-10
vue3.x項(xiàng)目中,出現(xiàn)紅色波浪線問題及解決
這篇文章主要介紹了vue3.x項(xiàng)目中,出現(xiàn)紅色波浪線問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
Vue3?Composition?API優(yōu)雅封裝第三方組件實(shí)例
這篇文章主要為大家介紹了Vue3?Composition?API優(yōu)雅封裝第三方組件實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07

