有没有类似于'finally'jQuery中的AJAX调用
Is there any analog to a 'finally' in jQuery AJAX calls?
在jQuery AJAX调用中是否存在Java 'finally'类比?这里有这个代码。在我的always中,我抛出一个异常,但是我总是希望它转到then()方法。
call.xmlHttpReq = $.ajax({
url : url,
dataType : 'json',
type : 'GET'
}).always(function(processedDataOrXHRWrapper, textStatus, xhrWrapperOrErrorThrown) {
throw "something";
}).then(function() {
alert("i want to always run no matter what");
});
我已经尝试使用done(), complete()和另一个always(),但似乎没有任何工作。
这里是JSFiddle:
http://jsfiddle.net/qv3t3L0m/请看下面的例子:
$.ajax({
type: "GET",
dataType: dataType,
contentType: contentType,
async: TRUE,
url: $('html form:nth-child(1)').attr('action') + "?" $('html form:nth-child(1)').serialize(),
success: function(data) {
console.log("FUNFOU!");
},
error: function(data) {
console.log("NÃO FUNFOU!");
},
complete: function(data) {
console.log("SEMPRE FUNFA!");
//A function to be called when the request finishes
// (after success and error callbacks are executed).
}
});
更多信息:http://api.jquery.com/jquery.ajax/
.always()
应该可以工作。参见http://api.jquery.com/jQuery.ajax/的 jqXHR对象一节。
jqXHR。always(function(data|jqXHR, textStatus, jqXHR|errorThrown) {});完整回调选项的另一个构造是.always()方法取代已弃用的。complete()方法。
作为对成功请求的响应,函数的参数是与.done(): data、textStatus和jqXHR对象相同。为失败请求的参数与.fail()的参数相同:thejqXHR对象、textStatus和errorThrown。参考deferred.always()查看实现细节。
参见http://api.jquery.com/deferred.always/
下面的建议在jQuery中不起作用,因为jQuery的承诺实现不处理传递给它的方法中抛出的错误。我把它们留在这里只是为了说明如果jQuery是promises/A+兼容的,可能会发生什么。正如Bergi正确指出的那样,你将不得不在自己的try catch块中手动包装代码。
call.xmlHttpReq = $.ajax({
url : url,
dataType : 'json',
type : 'GET'
}).then(function(processedDataOrXHRWrapper, textStatus, xhrWrapperOrErrorThrown) {
throw "something";
}).always(function() {
alert("i want to always run no matter what");
});
虽然我不确定是否jquery的承诺支持总是,另一种选择是使用然后(再次)并传递相同的函数作为successHandler和errorHandler,像这样:
call.xmlHttpReq = $.ajax({
url : url,
dataType : 'json',
type : 'GET'
}).then(function(processedDataOrXHRWrapper, textStatus, xhrWrapperOrErrorThrown) {
throw "something";
}).then(function() {
alert("i want to always run no matter what");
},
function() {
alert("i want to always run no matter what");
});
对于那些使用jQuery 3.0及更高版本的人来说
弃用通知:jqXHR.success()、jqXHR.error()和jqXHR.complete()回调从jQuery 3.0开始删除。您可以使用jqXHR.done()、jqXHR.fail()和jqXHR.always()来代替。
官方文档
有一个bug ajax是依赖于服务器的,需要用"complete"来检查状态是最好的,一种"success", "error"等不是100%的PUT, POST和GET…看一个例子
$.ajax({
url: '/api/v2/tickets/123456.json',
....
....
....
complete: function(data) {
if (data.statusText == "success") {
console.log("Sent successfully");
} else {
console.log("Not Sent");
}
}
});
对不起,英语不好!欢欣鼓舞;-)
如果您想为所有ajax请求定义一个代码,您可以这样做
$(document).ajaxComplete(function () {
console.log('ajax complete on doc');
})
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作