繁体   English   中英

为什么jQuery.getJSON没有返回数据?

[英]Why does jQuery.getJSON return no data?

我有这个方法:

function getUserName(guid) {
    var name = "Unbekannt";

    $.getJSON(urlCurrent, {
        "method" : "get_user_info",
        "guid" : guid,
        "auth_token" : temporaryAuthToken
    }, function(data) {
        if (data.status == 0) {
            alert(data.result[0].name);
            name = data.result[0].name;
        }
    });

    return name;
}

几乎所有工作都在工作:Ajax-Request获取数据并触发回调函数,这样就可以了

alert(data.result[0].name);

显示一个具有此值的弹出窗口:“Forename Surname”

但是接着

return name;

该方法返回“Unbekannt”,但名称应该具有新值“Forename Surname”。 发生了什么事,错误在哪里?

多谢

我将从函数返回promise对象并对其进行操作。

function getUserName(guid) {
    return $.getJSON(urlCurrent, {
        "method" : "get_user_info",
        "guid" : guid,
        "auth_token" : temporaryAuthToken
    });
}

getUserName(guid).done(function(data) {
    if (data.status == 0) {
        alert(data.result[0].name);
    }
});

而且,如果你想在前面进行状态检查,那么就可以了。

function getUserName(guid) {
    return $.getJSON(urlCurrent, {
        "method" : "get_user_info",
        "guid" : guid,
        "auth_token" : temporaryAuthToken
    }).then(function(data){
        return $.Deferred(function(def){
            if (data.status == 0) {
                return def.resolve(data);
            }
            return def.reject(data);
        });
    });
}

getUserName(guid).done(function(data) {
    alert(data.result[0].name);
});

返回name ,尚未为getJSON回调分配新值,因为ajax调用是异步的,需要一些时间才能完成。

你需要带一个回调函数:

function getUserName(guid, callback) {
    var name = "Unbekannt";

    $.getJSON(urlCurrent, {
        "method" : "coinor.get_user_info",
        "guid" : guid,
        "auth_token" : temporaryAuthToken
    }, function(data) {
        if (data.status == 0) {
            alert(data.result[0].name);
            name = data.result[0].name;
            callback(name);
        }
    });
}

getUserName(guid, function(name) {
    alert(name);
});

因为return name; 在返回ajax调用之前执行。

如果您希望它与$.getJSON()调用中返回的数据相关,那么它也需要在回调函数内部。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM