做项目的时候使用axios进行前后端数据交互,这里就有一个问题,如何封装ajax请求,这个是我已经封装好了的,share出来我以后也会用到,对大家希望也有帮助
/*
ajax请求函数模块
返回值: promise对象(异步返回的数据是: response.data)
*/
import axios from 'axios'
export default function ajax (url, data={}, type='GET') {
return new Promise(function (resolve, reject) {
// 执行异步ajax请求
let promise
if (type === 'GET') {
// 准备url query参数数据
let dataStr = '' //数据拼接字符串
Object.keys(data).forEach(key => {
dataStr += key + '=' + data[key] + '&'
})
if (dataStr !== '') {
dataStr = dataStr.substring(0, dataStr.lastIndexOf('&'))
url = url + '?' + dataStr
}
// 发送get请求
promise = axios.get(url)
} else {
// 发送post请求
promise = axios.post(url, data)
}
promise.then(function (response) {
// 成功了调用resolve()
resolve(response.data)
}).catch(function (error) {
//失败了调用reject()
reject(error)
})
})
}
2、封装一个ajax的get请求
var Ajax={
get: function(url, fn) {
// XMLHttpRequest对象用于在后台与服务器交换数据
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
xhr.onreadystatechange = function() {
// readyState == 4说明请求已完成
if (xhr.readyState == 4 && xhr.status == 200) {
// 从服务器获得数据
fn.call(this, xhr.responseText);
}
};
xhr.send();
}
}
注意:ajax在接受响应之前还可以调用abort()方法取消异步请求
xhr.abort()
调用这个方法后,xhr对象就会通知触发事件,而且也不在荀彧访问任何与响应有关的对象属性,在终止请求之后,还应该对xhr对象进行解引用操作。由于内存原因,不建议重用xhr对象。
版权声明:本文为m0_49135418原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。