拒绝jQueryajax内部的延迟
reject deferred inside jQuery ajax
我正在使用$.ajax从服务器获取一些HTML。
我的javascript使用promise,我希望避免创建另一个promise,并使用jQueryajax,因为它已经是一个promise。
但是,有没有什么方法可以拒绝"done"回调中的承诺?
我的代码看起来像这样:
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?在完成的回调中?
有没有什么方法可以拒绝"done"回调中的承诺?
不,因为done
不会创建新的promise,并且只有在promise已经实现时才会被调用。您需要使用then
进行链接——它创建了一个可以从回调中拒绝的新承诺。然而,对于jQuery,这有点复杂,我们不能只在回调中使用throw
。
所以使用
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) {
// …
});
您的代码应该如下所示:
function get_html(){
return $.ajax({ .... });
}
get_html().done(function(response){
// process a response from your server here...
}).fail(function(){
// process errors here...
});
相关文章:
- 内部分区字体大小获胜'调整浏览器窗口大小时不会随媒体查询而更改
- 可以简化嵌套的延迟Q Promises解析吗
- 调用函数内部的函数
- 如何使用js将SNAPSHOT内部版本号转换为3位数的整数
- 在phonegap应用程序内部重定向不起作用
- 使用此选项选择父类内部的类
- 访问JSON对象内部的数组元素
- 从模块内部访问Express装载路径
- onclick函数需要双击,因为类分配延迟
- AngularJs指令,该指令创建内部有数据对象的新指令
- 如何使用内部对象构造对象
- 拒绝jQueryajax内部的延迟
- 函数内部的JavaScript延迟,没有全局变量
- 确保内部延迟完成,然后“然后”
- 循环内部的延迟不起作用
- 如何创建一个内部带有延迟/超时的 javascript 书签
- 包装jQuery.ajax:级联内部jqXHR作为一个新的延迟对象返回
- 需要循环两个循环,并在内部循环中使用延迟迭代
- 在setInterval函数内部使用时,Jquery延迟是不一致的
- 延迟循环内部的javascript代码执行