无法迭代Javascript对象

shs*_*yoo 3 javascript javascript-objects firebase firebase-realtime-database

我一直遇到访问JS对象中的数据的问题.收集数据的代码(来自Firebase数据库)如下:

var get_user_data = function() {
    ...
    snapshot.forEach(function(child){
        var key = child.key;
        var value = child.val();
        user_char[key] = value;
        console.log(key, value);
    });
    store_user_char(user_char);
}

var store_user_char = function(user_char) {
    char_obj = user_char;
    console.log(char_obj);
    for(var key in char_obj){
        if(char_obj.hasOwnProperty(key)){
            console.log(key);
        }
}
Run Code Online (Sandbox Code Playgroud)

哪个(理论上)应该从Firebase数据库创建JS对象,当它将数据写入user_char时,它会将每个键:对象对打印到控制台中.之后,当store_user_char()执行时,它还应打印出之前的每个键.

第一个console.log()在写入user_char时成功输出每个键:对象对.第二个console.log()成功输出对象,我甚至可以单击并编辑其中的所有元素,在Firefox控制台中如下所示:

对象属性

但是第三个console.log()永远不会执行,并试图通过访问如下所示的键从char_obj获取任何数据:

char_obj['KSxpjEvkCOL6ugGkxqn']
Run Code Online (Sandbox Code Playgroud)

什么都不做,返回undefined.奇怪的是,在Firefox中手动单击对象允许我解析每个子元素,因此我知道数据存储在某个地方.

我唯一能想到的是来自数据库的请求可能需要很长时间来返回数据,但即使这样,store_user_char()函数应该在数据存储到user_char之后执行,所以我非常困惑为什么我的代码似乎无法遍历对象.

我觉得好像我遗漏了一些关于JS对象的东西,这就是为什么我的代码无法找到数据的原因,但是我一直在试图找出最新情况,以及如何访问数据.

任何有关此事的帮助将不胜感激!

编辑:get_user_data的完全def如下:

// Global variables
var user_email;
var user_char = {};
var uid;

var get_user_data = function() {
    // Authenticate current user
    var user = firebase.auth().currentUser;

    // Get User Email and char list
    if (user != null) {
        user_email = user.email;
        uid = firebase.auth().currentUser.uid;
        var getChar = firebase.database().ref('/users/' + uid + '/chars/').orderByKey();
        getChar.on('value', function(snapshot){
            snapshot.forEach(function(child){
                var key = child.key;
                var value = child.val();
                user_char[key] = value;
            });
        });
        store_user_char(user_char);
    }
}
Run Code Online (Sandbox Code Playgroud)

Man*_*nnu 9

getChar.on('value', function(snapshot){
    snapshot.forEach(function(child){
        var key = child.key;
        var value = child.val();
        user_char[key] = value;
    });
});
Run Code Online (Sandbox Code Playgroud)

将异步调用,put函数调用store_user_char(user_char); 在getChar内部回调,你的问题将得到解决.喜欢:

getChar.on('value', function(snapshot){
        snapshot.forEach(function(child){
            var key = child.key;
            var value = child.val();
            user_char[key] = value;
        });
       store_user_char(user_char);
    });
Run Code Online (Sandbox Code Playgroud)