我可以编写一个回调函数,该函数将停止执行一个脚本,直到完成另一个脚本为止。我找到了它。

dosomething(4, function () {
    console.log("finished loop");
});


function dosomething(delay, callback) {

    for (var i = 0; i < 100; i++) {
        $("body").append(i + "<br>");
    }
    alert("done");
    if (typeof callback == "function") callback();

}


here

但是,这不适用于异步功能。我认为这就是原因。

doAjax(4, function () {
    console.log("finished ajax");
});

function doAjax(delay, callback) {
    $.ajax({
        type: "post",
        url: "/echo/html/",
        data: {
            html: "some content",
            delay: 4
        },
        dataType: 'html',
        success: function () {
            console.log("ajax done");
        }
    });

    if (typeof callback == "function") callback();
}


FIDDLE

我知道问如何为异步请求合并我自己的回调有点愚蠢,因为jQuery内置了它们,而我只是使用了一个,但是我想知道如何实现。它与编写整个Promise库一样复杂吗?

最佳答案

请求完成后,您不会再调用回调。


...
//HERE!
success: function(data){
  if (typeof callback == "function") callback(null, data);
},
error: callback
...
//NOT BELOW

07-24 19:12
查看更多