我正在努力使用承诺的 ajax GET。 如果 ajax 遇到错误,例如 URL 不正确,则会调用 'error: function ()' 并且我在浏览器调试中收到错误消息“Uncaught (in promise) undefined”
ajax 函数的前两部分工作正常,即如果 ajax 返回成功,则 result.success true/false 的两个内部条件都有效,我只是不知道如何解决 ajax 中的拒绝调用底部误差函数:
var myVariable = "test";
let promise = myFunction(myVariable);
promise.then(function () {
// Do Something
}).catch(function (message) {
console.error(message);
});
function myFunction(myVariable) {
return new Promise(function (resolve, reject) {
$.ajax({
type: "GET", //send it through get method
url: "/myURL/Edit?handler=GetBlahBlah",
data: {
sourceType: myVariable
},
contentType: "json",
dataType: "json",
success: function (result) {
if (result.success == false) {
reject(result.responseText); // This works
} else {
resolve(); // This works
}
},
error: function () {
reject("Error while making Ajax call! Get Trigger"); // NOT WORKING!!
}
});
});
}
答案 0 :(得分:0)
原来我的原始问题确实可以正常工作,起初我没有注意到这个 ajax GET 请求的调用方法来自我的 javascript 中不同时间的两个不同进程,而且我没有包含 catch 块在第一次实际调用这个ajax的过程中。 如果我对任何人造成任何混淆,我很抱歉!