针对jquery的when方法做的应变
Posted qingwengang
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了针对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方法满足都成功就往下执行的条件。
以上是关于针对jquery的when方法做的应变的主要内容,如果未能解决你的问题,请参考以下文章