等待多个getJSON调用完成

等待多个getJSON调用完成,第1张

等待多个getJSON调用完成

如果您使用jQuery的deferred,这很容易。有一种方法,

$.when
等待多个诺言完成,然后运行回调。那就是你应该在这里使用的。

不要使用全局

obj
变量,您可以只使用AJAX调用的返回值。

function getData(id) {    var thisI = i;    var url = "www.whatever.com?id=" + id;    return $.getJSON(url);  // this returns a "promise"}

因此,

obj
我们没有填充,而是返回了诺言。然后,在您的循环中,您收集了所有这些。

var AJAX = [];for (i=0; i < ids.length; i++) {    AJAX.push(getData(ids[i]));}

然后,当所有这些 *** 作完成后,我们需要连接回调:

$.when.apply($, AJAX).done(function(){    // This callback will be called with multiple arguments,    // one for each AJAX call    // Each argument is an array with the following structure: [data, statusText, jqXHR]    // Let's map the arguments into an object, for ease of use    var obj = [];    for(var i = 0, len = arguments.length; i < len; i++){        obj.push(arguments[i][0]);    }    document.getElementById("txt").innerHTML = obj[0]['field'];});


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5013348.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-15
下一篇 2022-11-14

发表评论

登录后才能评论

评论列表(0条)

保存