我有一个格式为的JSON对象:
{
"z061": {
"status": "restored",
"time": 135
},
"z039": {
"status": "restored",
"time": 139
}, ...
}
其中有64个区域编号为z001到z064。
根据区域z001到z015的“状态”,Javascript填充表格的最佳方法是什么?这是我当前的代码,仅评估区域z003:
setInterval(function() {
$.getJSON("http://rackserver.local:8080",function(data) {
var temp = data.z003.status;
if (temp != "restored")
$("#securityTable tr:eq(3)").removeClass("error").addClass("success");
else
$("#securityTable tr:eq(3)").removeClass("success").addClass("error");
});
}, 1500);
答案 0 :(得分:1)
您可以使用点运算符或索引器运算符访问对象,此任务适用于索引器。
for (var i = 1; i <=15; i++){
// hardcoded the check to make it easier.
if (i >= 10)
var temp = data["z0" + i].status;
else
var temp = data["z00" + i].status;
}
答案 1 :(得分:0)
$.getJSON("http://rackserver.local:8080",function(data) {
$.each( data, function( key, value ) {
if (data[key].status != "restored") {
//do your stuff
} else {
//do more stuff
}
});
答案 2 :(得分:0)
这是我提出的代码。
setInterval(function() {
$.getJSON("http://rackserver.local:8080",function(data) {
var i = 1, j;
for (; i <= 64; i += 1) {
j = 'z';
if (i < 10) j += '0';
if (i < 100) j += '0';
if (data[j + i].status !== "restored")
$("#securityTable tr:eq(" + i + ")").removeClass("error").addClass("success");
else
$("#securityTable tr:eq(" + i + ")").removeClass("success").addClass("error");
}
}, 1500);
希望这有帮助。