我正在尝试构建一个发出ajax请求的Google Chrome扩展程序。类似于GMail Checker扩展的东西。问题是当我使用jquery执行请求时,我输入了错误的用户名/密码,它会无声地失败,并忽略错误回调函数。
如果我将ajax调用移出background.html脚本(我在开发人员窗口中看不到请求),那么对于options.html脚本,我会得到一个重新进行身份验证的对话框。如果我点击取消,那么jquery错误回调就会触发。
但是在原始模型扩展程序(再次是Gmail检查程序)中,他们使用带有try / catch的普通(非jquery)ajax调用,如果我输入了错误的凭据,我会收到一个警告说同样多。
我尝试在try / catch中包装整个jquery调用,如下所示:
try {
$.ajax({
type: "POST",
url: someurl,
contentType : "text/xml",
data: somedata,
username: user,
password: pass,
success: function(data,status,xhr){
alert("Hurrah!");
},
error: function(xhr, status, error){
alert("Error!" + xhr.status);
},
dataType: "xml"
});
} catch(e) {
alert("You messed something up!");
}
但仍然没有。
错误是由于它是异步的,还是Chrome没有将请求作为错误返回,因为它想要重新提示凭据?或者我只是不知道如何使用try / catch?
以下是模型代码如何处理请求的非常简洁的版本:
var req = new XMLHttpRequest();
req.onreadystatechange = function() {
try {
if ( req.readyState == 4 ) {
//Do some stuff with results
}
}
catch (ex) {
alert('Error parsing response.');
}
}
try {
req.send (data);
}
catch (ex) {
alert ('Something went wrong with the request.');
}
答案 0 :(得分:13)
尝试更像这样的东西,无论发生什么,你都有一个在完成每个请求后运行的函数。这应该可以解决问题:
// Store a global var so we can all play nicely.
// Make sure this gets reset to false right before your AJAX call,
// or it will only work once!
var weHaveSuccess = false;
$.ajax({
type: "POST",
url: someurl,
contentType : "text/xml",
data: somedata,
username: user,
password: pass,
success: function(data,status,xhr){
alert("Hurrah!");
weHaveSuccess = true;
},
error: function(xhr, status, error){
alert("Error!" + xhr.status);
},
complete: function(){
if(!weHaveSuccess){
alert('Your username/password seems to be incorrect!');
}
},
dataType: "xml"
});
答案 1 :(得分:3)
ajax错误回调函数本身不会抛出异常。如果你想尝试一下try / catch,你可能会在错误函数中throw出现异常。这将触发您周围的捕获。
PS!有时您需要在需要评估结果时在ajax调用中设置async:false参数,因为默认情况下,代码将在启动ajax请求后继续,并在稍后阶段异步调用成功或错误回调并且仅调用代码。