我有这个代码:
loadData : function(jsonArray) {
var id = $(this).attr("id");
for(var i in jsonArray) {
$("#"+id+" tbody").append('<tr class="entry-details page-1 entry-visible" id="entry-'+i+'"></tr>');
var header = {
1: "time",
2: "project",
3: "task"
}
var col = 1;
while(col <= jsonArray[i].length) {
$("#"+id+" tbody #entry-"+i).append("<td>"+jsonArray[i][header[col]]+"</td>")
col++
}}
它将采用类似于以下
的JSON数组{"1":{"project":"RobinsonMurphy","task":"Changing blog templates","time":"18\/07\/11 04:32PM"},"2":{"project":"Charli...
代码应循环遍历行(它会执行),然后循环遍历数据列。
我面临的问题是为了将列数据放在正确的列中,我需要计算连续返回多少条数据。我尝试了jsonArray [i] .length,但这会返回undefined。
任何帮助将不胜感激
答案 0 :(得分:4)
您根本没有任何数组,只有对象。
要计算对象中的项目,请创建一个简单的函数:
function countInObject(obj) {
var count = 0;
// iterate over properties, increment if a non-prototype property
for(var key in obj) if(obj.hasOwnProperty(key)) count++;
return count;
}
现在,您可以致电countInObject(jsonArray[i])
。
答案 1 :(得分:2)
像这样:
Object.size = function(obj) {
var size = 0, key;
for (key in obj) {
if (obj.hasOwnProperty(key)) size++;
}
return size;
};
// Get the size of an object
var size = Object.size(myArray);
答案 2 :(得分:0)
看看那个小提琴: http://jsfiddle.net/Christophe/QFHC8/
键是
for (var j in jsonArray[i]) {
而不是
while (col <= jsonArray[i].length) {
答案 3 :(得分:0)
jsonArray [i] .length将无效,因为jsonArray [i]是一个字典而不是一个数组。你应该尝试类似的东西:
for(var key in jsonArray[i]) {
jsonArray[i][key]
}
答案 4 :(得分:0)
我一直面临着同样的问题,我编写了一个函数,它可以将多维数组/对象中的所有标量值组合在一起。如果对象或数组是空的,那么我认为它不是一个值,所以我不能将它们相加。
function countElements(obj) {
function sumSubelements(subObj, counter = 0) {
if (typeof subObj !== 'object') return 1; // in case we just sent a value
const ernation = Object.values(subObj);
for (const ipated of ernation) {
if (typeof ipated !== 'object') {
counter++;
continue;
}
counter += sumSubelements(ipated);
}
return counter;
}
return sumSubelements(obj);
}
let meBe = { a: [1, 2, 3, [[[{}]]]], b: [4, 5, { c: 6, d: 7, e: [8, 9] }, 10, 11], f: [12, 13], g: [] };
const itution = countElements(meBe);
console.log(itution); // 13
let tuce = [1,2];
console.log(countElements(tuce)); // 2
console.log(countElements(42)); // 1
或者如果你想在制作中使用它,你甚至可以考虑将它添加到Object原型中,如下所示:
Object.defineProperty(Object.prototype, 'countElements', {
value: function () {
function sumSubelements(subObj, counter = 0) {
const subArray = Object.values(subObj);
for (const val of subArray) {
if (typeof val !== 'object') {
counter++;
continue;
}
counter += sumSubelements(val);
}
return counter;
}
return sumSubelements(this);
},
writable: true,
});
console.log(meBe.countElements()); // 13
console.log([meBe].countElements()); // 13; it also works with Arrays, as they are objects