访问循环javascript外部的数组变量

时间:2015-07-21 14:09:57

标签: javascript jquery json loops datatables

我正在尝试使用datatables jquery库填充表,遇到的问题是只显示最后一个值,通过循环存储在json中的数据来访问这些值。这是我的代码: -

for (var i = 0; i < json_parsed.Users.length; i++) {
    var user = json_parsed.Users[i];
    if (user.position == "GK") {
        goalkepeers = [{
            "playerID": user.playerID,
            "playerName": user.playerName,
        }];
    }
}



$('#myTable').dataTable({
    "aaData": goalkepeers,
    "aoColumns": [{
            "mDataProp": "playerID"
        }, {
            "mDataProp": "playerName"
        },

    ]
});

一切正常但我的表中只显示一个数据,数组应该是这样的

goalkepeers = [{
    "playerID": player1ID,
    "playerName": player1Name,
}, 
{   
    "playerID": player2ID,
    "playerName": player2Name,
}];

任何帮助将不胜感激,再次感谢:-)

3 个答案:

答案 0 :(得分:2)

试试这个,全局宣告守门员,然后每次在循环中宣告守门员并将其推入守门员阵列:

var goalkeepers = [];
for (var i = 0; i < json_parsed.Users.length; i++){  
             var user = json_parsed.Users[i];
             if(user.position=="GK"){
                var goalkeeper= {
                "playerID": user.playerID,
                 "playerName":user.playerName,
                     };
                goalkeepers.push(goalkeeper);
               }
}  

答案 1 :(得分:1)

发生这种情况是因为您要替换值:

before

答案 2 :(得分:0)

在循环之前定义数组

goldkeepers= array();

然后在循环内部做

goalkepeers.push({
        "playerID": user.playerID,
        "playerName": user.playerName,
    });

在你的代码中你的数组每次被下一个json_parsed.Users元素覆盖,所以最终结果是一个只有最后一个元素的数组