封裝的js文件以下:ios
/* 用於修改 axios 的一些公用配置,具體參看文檔 */
import axios from 'axios'
import store from '@/store/index.js'
import qs from 'qs'
import { isJSON } from '@/utils/utils'
import { getToken } from '@/common/js/cache'
// import { ROOT_URL } from '@/configs/config'ajax
axios.defaults.transformRequest = (data, headers) => {
if (store.getters.token) {
headers['accesstoken'] = getToken() // 讓每一個請求攜帶自定義token 請根據實際狀況自行修改
}
if (headers['Content-Type'] === 'application/x-www-form-urlencoded' && data && Object.prototype.toString.call(data) === '[object Object]') {
data = qs.stringify(data)
}
return data
}json
const newAxios = axios.create({
timeout: 1500000
})axios
newAxios.interceptors.request.use(config => {
return config
}, err => {
return Promise.reject(err)
})服務器
newAxios.interceptors.response.use(response => {
const accesstoken = response.headers.accesstoken
// debugger
const res = isJSON(response.data) ? response.data : JSON.parse(response.data)
if (accesstoken && isJSON(res.data)) {
res.data.accesstoken = accesstoken
}
return response.data
}, err => {
if (err.code === 'ECONNABORTED' && err.message.indexOf('timeout') !== -1) {
// Message.error('請求超時。。。')
console.log('請求超時。。。')
}app
console.log(err)
return Promise.reject(err)
})post
export function request (_param) {
const {
method = 'get',
// `responseType` 表示服務器響應的數據類型,能夠是 'arraybuffer', 'blob', 'document', 'json', 'text', 'stream'
responseType = 'json', // 默認的
headers = {},
url = '',
params,
data,
...otherData
} = _paramurl
if (!url) {
return new Promise((resolve, reject) => {
reject(new Error('url is null'))
})
}
const _method = method.toLowerCase()prototype
if (_method === 'get') {
return newAxios({
responseType,
url,
headers,
method,
params: params || data || otherData
})
}debug
if (_method === 'post' || _method === 'delete' || _method === 'put') {
if (!headers.hasOwnProperty('Content-Type')) {
headers['Content-Type'] = 'application/x-www-form-urlencoded'
}
if (params && data) {
return newAxios({
responseType,
url,
headers,
method,
params,
data
})
} else {
const { start, limit, ...resetData } = otherData
return newAxios({
responseType,
url,
headers,
method,
params: params || { start, limit },
data: data || resetData
})
}
}
}
export default newAxios
接下來就是其餘文件做爲公用的請求進行使用了,以登錄爲例子:
import { request } from '@/common/js/ajax'
import MD5 from 'crypto-js/md5'
import { getToken } from '@/common/js/cache'
export function login ({ userNo, password }) { const url = '/v1/security/logon' return request({ url, method: 'post', data: { userNo, password: MD5(password).toString() } })}