javascript - 关于jQuery deferred 多个AJAX执行问题
PHP中文网
PHP中文网 2017-04-11 12:56:23
0
1
350

我写了两个函数,分别是使用AJAX请求数据,为了能控制他们的执行顺序,也不想改变AJAX的异步开关,发现使用deferred写法后,fail和done方法都执行了

代码:

    function func1(dfd) {
         
            $.ajax({
                type: "POST",
                timeout: 10 * 1000,
                contentType: "application/x-www-form-urlencoded; charset=utf-8",
                data: { },
                url: ""
            }).done(function (msg) {
                dfd.resolve();
            }).fail(function (XMLHttpRequest, textStatus, errorThrown) {
                dfd.reject();
            });
        }

        return dfd;
    }
    
            function func2() {
        $.ajax({
            type: "POST",
            timeout: 5 * 1000,                
            contentType: "application/x-www-form-urlencoded; charset=utf-8",
            data: {  },
            url: ""
        }).done(function (msg) {
            }
        }).fail(function (XMLHttpRequest, textStatus, errorThrown) {
            console.log(XMLHttpRequest.status + "|" + XMLHttpRequest.statusText);
        });
    }
    
    $(document).ready(function () {            
        var defer = new $.Deferred();
        $.when(fucn1(defer)).done(func2()).fail(function () { alert("fail") });
        });
PHP中文网
PHP中文网

认证高级PHP讲师

répondre à tous(1)
阿神
你写的代码有问题,我帮你改了下:

function func1(dfd) {
     
        $.ajax({
            type: "POST",
            timeout: 10 * 1000,
            contentType: "application/x-www-form-urlencoded; charset=utf-8",
            data: { },
            url: ""
        }).done(function (msg) {
            dfd.resolve();
        }).fail(function (XMLHttpRequest, textStatus, errorThrown) {
            dfd.reject();
        });
        return dfd;
    }
    // return dfd;



        function func2() {
    $.ajax({
        type: "POST",
        timeout: 5 * 1000,                
        contentType: "application/x-www-form-urlencoded; charset=utf-8",
        data: {  },
        url: ""
    }).done(function (msg) {
        }
    }).fail(function (XMLHttpRequest, textStatus, errorThrown) {
        console.log(XMLHttpRequest.status + "|" + XMLHttpRequest.statusText);
    });
}

$(document).ready(function () {            
    var defer = new $.Deferred();
    // func1
    $.when(func1(defer)).done(func2()).fail(function () { alert("fail") });
    });
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal