如何二次封装zepto中ajax的promise写法,来实现数据预处理?

发布于 2022-09-02 13:33:52 字数 528 浏览 17 评论 0

我希望写一个公用的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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

美人骨 2022-09-09 13:33:52

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;
};
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文