我正在尝试使用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,
}];
任何帮助将不胜感激,再次感谢:-)
答案 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元素覆盖,所以最终结果是一个只有最后一个元素的数组