微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

拒绝在jQuery ajax中延迟

我正在使用$.ajax从服务器获取一些HTML.

我的JavaScript使用了promises,我想避免创建另一个promise并使用jQuery ajax,因为它已经是一个promise.

但是,有什么方法可以拒绝“完成”回调中的诺言吗?

我的代码看起来像这样:

function get_html(){

   return $.ajax({ .... }).done(function(response){

     if(response.haveErrors){
       // here how do I reject and return the promise?
       return;
     }

     // code #2 should run normally
     // but can i pass a "parameter" to done() ?

   }).fail(function(){
      ....
   });
}

用法

get_html().done(function(parameter){
      // code #2
    }).fail(function(){

});

另外,是否可以将参数传递给代码2?在完成的回调中?

解决方法:

Is there some way I can reject the promise inside the “done” callback?

不可以,因为完成不会创建新的承诺,并且仅在承诺已实现时才调用.您需要使用then进行链接-它会创建一个新的Promise,可以从回调中拒绝它.但是,使用jQuery this is a bit more complicated,我们不能仅仅抛出回调.

所以用

function get_html() {
    return $.ajax({…}).then(function(response) {
        if (response.hasErrors) {
            return $.Deferred().reject(response.errors);
        }
        // else
        return response; // which is getting passed as the parameter below
    });
}

接着

get_html().then(function(parameter) {
  // code #2
}, function(err) {
  // …
});

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐