`

针对jquery的when方法做的应变

阅读更多
需求:a,b两个任务都处理(不管a,b是成功还是失败)后,执行后面的任务。
代码1:
  
var leftResult = leftPromise.then(
    function (value) {    
        console.info("jsonA end");
    }, function () {
        console.info("jsonA fail");
    }
);
 
var rightResult = rightPromise.then(
    function (value) {
        console.info("jsonB end");
    }, function () {
        $("#jsonB").val("");
        console.info("jsonB fail");
    }
);
 
$.when(leftResult, rightResult).always(
    function(){
        console.info("start compare");
    });
 

  可能出现a任务失败后,直接执行后面的任务了
when方法的定义就是任意失败,或者全部成功就往下执行。怎么办呢?
通过一个always的包装解决:


  
var leftResult = leftPromise.then(
    function (value) {    
        console.info("jsonA end");
    }, function () {
        console.info("jsonA fail");
    }
).always(
    function () {
        console.info("jsonA always");
        var d = $.Deferred();
        d.resolve();
        return d.promise();
    }
);
var rightResult = rightPromise.then(
    function (value) {
        console.info("jsonB end");
    }, function () {
        $("#jsonB").val("");
        console.info("jsonB fail");
    }
).always(
    function () {
        console.info("jsonB always");
        var d = $.Deferred();
        d.resolve();
        return d.promise();
    }
);
$.when(leftResult, rightResult).always(
    function(){
        console.info("start compare");
    });
 

这里的重点是then后面有个always,always方法返回的一定是成功的,让when方法满足都成功就往下执行的条件。





0
1
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics