返回值:Deferred Objectdeferred.then(doneFilter [, failFilter ] [, progressFilter ])

概述

添加处理程序被调用时,递延对象得到解决或者拒绝。

所有三个参数(包括progressCallbacks ,在jQuery的1.7 )可以是一个单独的函数或一个函数的数组。 其中一个参数,也可以为空,如果没有该类型的回调是需要的。或者,使用.done()或.fail()仅设置doneCallbacks或failCallbacks。当递延解决,doneCallbacks被调用。若递延代替拒绝,failCallbacks被调用。回调按他们添加的顺序执行。一旦deferred.then返回延迟对象,延迟对象的其它方法也可以链接到了这里,包括增加.then()方法。有关详细信息,请参阅文件Deferred object

参数

doneFilter [, failFilter ] [, progressFilter ] StringV1.8

doneFilter: 当Deferred(延迟)对象得到解决时被调用的一个函数。

failFilter: [可选]当Deferred(延迟)对象拒绝时被调用的一个函数。

progressFilter:[可选]当Deferred(延迟)对象生成进度通知时被调用的一个函数。

doneCallbacks,failCallbacksStringV1.5

doneCallbacks: 一个函数或函数数组,当延迟成功时调用。

failCallbacks: 一个函数或函数数组,当延迟失败时调用。

doneCallbacks, failCallbacks [, progressCallbacks]StringV1.7

doneCallbacks: 一个函数或函数数组,当延迟解决时调用。

failCallbacks: 一个函数或函数数组,当延迟拒绝时调用。

progressCallbacks: 一个可选的函数,当延迟对象通知进度(progress)时被调用。

示例

描述:

一旦jQuery.get方法返回一个来自延迟的对象的jqXHR对象,我们可以附加一个成功回调使用.then方法。

jQuery 代码:
$.get("test.php").then(
    function(){ alert("$.get succeeded"); },
    function(){ alert("$.get failed!"); }
);