zoukankan      html  css  js  c++  java
  • jquery的deferred对象

    本文参考阮一峰的《jQuery的deferred对象详解》,主要是方便自己查阅,如果要了解deferred,建议移步原文查看。

    deferred对象是JQuery 1.5.0版本开始引入的一个新功能,是提升jquery回调函数的解决方案。

    Deferred对象

    $.deferred() 生成一个deferred对象

    deferred.done() 指定操作成功时的回调函数

    deferred.fail() 指定操作失败时的回调函数

    deferred.promise() 没有参数时,返回一个新的deferred对象,该对象的运行状态无法被改变;接受参数时,作用为在参数对象上部署deferred接口

    deferred.reject() 这个方法与deferred.resolve()正好相反,调用后将deferred对象的运行状态改变为“已失败”,从而立即触发fail()方法

    $.when() 为多个操作指定回调函数

    deferred.when() 有时为了省事,可以把done()和fail()合在一起,这就是then()方法

    $.when($.ajax( "/main.php" ))
    
      .then(successFunc, failureFunc );

    deferred.always() 这个方法也是用来指定回调函数的,它的作用是不管调用deferred.resolve()还是deferred.reject(),最后总会调用该方法

    $.ajax( "test.html" )
    
      .always( function() { alert("已执行!");} );

    例一:直接在wait对象上部署deferred接口

    var dtd = $.Deferred(); // 生成Deferred对象
    
    var wait = function(dtd){
    
      var tasks = function(){
    
        alert("执行完毕!");
    
        dtd.resolve(); // 改变Deferred对象的执行状态
    
      };
    
      setTimeout(tasks,5000);
    
    };
    
    dtd.promise(wait);
    
    wait.done(function(){ alert("哈哈,成功了!"); })
    
    .fail(function(){ alert("出错啦!"); });
    
    wait(dtd);

    例二:使用deferred对象的建构函数$.Deferred()

    $.Deferred(wait)
    
    .done(function(){ alert("哈哈,成功了!"); })
    
    .fail(function(){ alert("出错啦!"); });

    例三:原来的deferred对象上返回另一个deferred对象,后者只开放与改变执行状态无关的方法(比如done()方法和fail()方法),屏蔽与改变执行状态有关的方法(比如resolve()方法和reject()方法),从而使得执行状态不能被改变

    var dtd = $.Deferred(); // 新建一个Deferred对象
    
    var wait = function(dtd){
    
      var tasks = function(){
    
        alert("执行完毕!");
    
        dtd.resolve(); // 改变Deferred对象的执行状态
    
      };
    
      setTimeout(tasks,5000);
    
      return dtd.promise(); // 返回promise对象
    
    };
    
    var d = wait(dtd); // 新建一个d对象,改为对这个对象进行操作
    
    $.when(d)
    
    .done(function(){ alert("哈哈,成功了!"); })
    
    .fail(function(){ alert("出错啦!"); });
    
    d.resolve(); // 此时,这个语句是无效的

    更好的写法是allenm所指出的,将dtd对象变成wait()函数的内部对象

    var wait = function(dtd){
    
      var dtd = $.Deferred(); //在函数内部,新建一个Deferred对象
    
      var tasks = function(){
    
        alert("执行完毕!");
    
        dtd.resolve(); // 改变Deferred对象的执行状态
    
      };
    
      setTimeout(tasks,5000);
    
      return dtd.promise(); // 返回promise对象
    
    };
    
    $.when(wait())
    
    .done(function(){ alert("哈哈,成功了!"); })
    
    .fail(function(){ alert("出错啦!"); });

    例四:为多个操作指定回调函数

    $.when($.ajax("test1.html"), $.ajax("test2.html"))
    
    .done(function(){ alert("哈哈,成功了!"); })
    
    .fail(function(){ alert("出错啦!"); });

    例五:指定同一操作的多个回调函数

    $.ajax("test.html")
    
    .done(function(){ alert("哈哈,成功了!");} )
    
    .fail(function(){ alert("出错啦!"); } )
    
    .done(function(){ alert("第二个回调函数!");} );
  • 相关阅读:
    log4j.appender.stdout.layout.ConversionPattern
    log4j:WARN No appenders could be found for logger
    Eclipse中TODO的分类,以及自动去除
    Java泛型类型擦除导致的类型转换问题
    Java中泛型数组的使用
    Java泛型中的通配符的使用
    Java泛型类定义,与泛型方法的定义使用
    Java泛型的类型擦除
    jQuery查询性能考虑
    jQuery判断checkbox是否选中
  • 原文地址:https://www.cnblogs.com/ywang/p/7356702.html
Copyright © 2011-2022 走看看