Javascript Ajax Uncaught (in promise) undefined

时间:2021-01-10 22:35:50

标签: javascript ajax promise

我正在努力使用承诺的 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!!
            }
        });
    });
}

1 个答案:

答案 0 :(得分:0)

原来我的原始问题确实可以正常工作,起初我没有注意到这个 ajax GET 请求的调用方法来自我的 javascript 中不同时间的两个不同进程,而且我没有包含 catch 块在第一次实际调用这个ajax的过程中。 如果我对任何人造成任何混淆,我很抱歉!