微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – jQuery递归AJAX调用Promise

我还在试图弄清楚如何在递归的AJAX调用中使用jQuery延迟对象.我有这样的代码

function request(page, items){    

    //building the AJAX return value for JSfiddle dummy AJAX endpoint
    var ret = {
        totalPage: 10,
        currentPage: page,
        items: []
    };
    for (var i = page; i < (page + 5); i++){
        ret.items.push(i);
    }

    //calling the AJAX
    $.ajax({
        url: '/echo/json/',
        method: 'POST',
        dataType: 'json',
        data: {
            delay: 1,
            json: JSON.stringify(ret)
        },
        success: function(data){
            if (data.currentPage <= data.totalPage){
                var filtered = data.items.filter(function(el){
                    return el % 2 == 1;
                });
                var newitems = items.concat(filtered);
                console.dir(newitems);
                request(data.currentPage + 1, newitems);
            } else {
                console.dir(items);
                //resolve all item
            }
        }
    });
}

function requestAll(){
    request(1, []);
    //should return a promise tha contains all items
}

这是JSfiddle http://jsfiddle.net/petrabarus/BHswy/

我知道如何在单个AJAX调用中使用promise,但我不知道如何在递归的AJAX调用中使用它.我想以类似下面的方式调用requestAll函数

var promise = requestAll();
promise.done(function(items){
    console.dir(items);
});

我怎样才能做到这一点?

解决方法:

如果要使用promises,则不应使用success参数.相反,你想要返回一个promise,然后你想使用then将promise的结果转换成不同的东西,甚至是另一个promise.

function request(page) {    
    …
    // return the AJAX promise
    return $.ajax({
        url: '/echo/json/',
        method: 'POST',
        dataType: 'json',
        data: {
            delay: 1,
            json: JSON.stringify(ret)
        }
    });
}

function requestOddsFrom(page, items) {
    return request(page).then(function(data){
        if (data.currentPage > data.totalPage) {
            return items;
        } else {
            var filtered = data.items.filter(function(el){ return el%2 == 1; });
            return requestOddsFrom(data.currentPage + 1, items.concat(filtered));
        }
    });
}

function requestAll(){
    return requestOddsFrom(1, []);
}

requestAll().then(function(items) {
    console.dir(items);
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐