gpt4 book ai didi

javascript - Jquery 延迟未按预期运行

转载 作者:行者123 更新时间:2023-12-02 14:44:37 25 4
gpt4 key购买 nike

我进行了 2 个 ajax 调用。仅当第一个完成时才应调用第二个:

var deferred = $.Deferred();

firstAjaxCall();

deferred.done(function () {
secondAjaxCall();
});

function firstAjaxCall() {
$.ajax({
url: '/SomeUrl',
type: 'POST',
success: function () {
deferred.resolve();
}
});
}

function secondAjaxCall() {
$.ajax({
url: '/SomeOtherUrl',
type: 'Get',
});
}

我也尝试过这样( jQuery deferreds )

$.when(firstAjaxCall()).done(function() {
secondAjaxCall();
});

但没有运气。

尽管如此,在第一个示例中,有时第二个调用会先被调用,有时则不会

在第一个示例中,流程如下:

firstAjaxCall();
secondAjaxCall();
deferred.resolve();

为什么第二个调用首先被调用并且在 deferred.resolve() 之前调用?

最佳答案

您必须实际将 Deferred 从 $.ajax 返回到 $.when 才能正常工作

function firstAjaxCall() {
return $.ajax({
url : '/SomeUrl',
type : 'POST'
});
}

function secondAjaxCall(data_from_first) {
return $.ajax({
url : '/SomeOtherUrl',
type : 'Get',
});
}

firstAjaxCall().done(secondAjaxCall);

关于javascript - Jquery 延迟未按预期运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36710857/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com