kat*_*tie 4 javascript ajax jquery promise
我正在使用$ .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(){
....
});
}
Run Code Online (Sandbox Code Playgroud)
和用法:
get_html().done(function(parameter){
// code #2
}).fail(function(){
});
Run Code Online (Sandbox Code Playgroud)
另外,是否可以将参数传递给代码2?在完成的回调中?
有什么方法可以拒绝“完成”回调中的promise?
不,因为done不会创建新的承诺,并且仅在承诺已实现时才调用。您需要then用于链接-它会创建一个新的Promise,可以从回调中拒绝它。但是,使用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
});
}
Run Code Online (Sandbox Code Playgroud)
然后
get_html().then(function(parameter) {
// code #2
}, function(err) {
// …
});
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2206 次 |
| 最近记录: |