javascript - 如何二次封装zepto中ajax的promise写法,来实现数据预处理?
本文介绍了javascript - 如何二次封装zepto中ajax的promise写法,来实现数据预处理?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
我希望写一个公用的ajax方法,在这个公用方法里能对服务器返回的数据做一些预处理,然后别的地方使用这个二次封装的ajax方法后,能拿到预处理后的数据,伪代码如下:
window.app=app||{};
app.ajax=function(options){
//这是二次封装的ajax方法,对请求的服务器的数据做预处理
// $.ajax(options)
};
//模块内调用ajax
app.ajax({
url:"xxxx",
method:'post'
}).done(function(resp){
console.info("我希望在这里获取到的resp是我在公用方法预处理过的数据",resp)
});
目前使用的是zepto.js,并且该zepto.js已经支持promise写法了,由于无法上传js文件,只能让大家去zepto官网自己下载zepto,然后看readme.MD按照说明重新npm 构建带promise的zepto.js,传送门:https://github.com/madrobby/zepto
解决方案
Zepto 的 Promise 和 ES2015 的 Promise 略有不同,不过使用起来也差不多,如果不考虑差异的问题,可以这样:
app.ajax = function(options) {
// 如果需要,在这里根据 url、method 处理 options
return $.ajax(options);
}
如果你还需要处理返回的数据,可以这样
app.ajax = function(options) {
// 如果需要,在这里根据 url、method 处理 options
var d = $.Deferred();
$.ajax(options).done(function(data) {
var d = handle(data); // 这里按你的需求处理 data
d.resolve(d);
}).fail(function() {
d.reject();
});
return d;
};
这篇关于javascript - 如何二次封装zepto中ajax的promise写法,来实现数据预处理?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文