J'ai un problème construire une table HTML à partir du JSON suivantJavaScript: Construire une table HTML à partir d'un JSON imbriqué
[
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children" : false
},
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children" : false
},
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children":[
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children" : false
},
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children" : false
}
]
},
{
"size" : 167,
"price" : 453400,
"type" : "Neubau",
"children" : false
}
]
lorsque introduit dans ces fonctions
function getRowHTML(dataObject, type) {
cycles = dataObject.length;
var markup = '';
for (var i=0; i < cycles; i++) {
// different markup for each line
switch (type) {
case 'size':
markup += ' <td>' + dataObject[i].size + '</td>';
break;
case 'price':
markup += ' <td>' + addDots(dataObject[i].price) + '€ </td>';
break;
case 'type':
markup += ' <td>' + dataObject[i].type + '</td>';
break;
}
// Check if an object has children and insert children HTML as well
if (dataObject[i].children) {
markup += getRowHTML(dataObject[i].children,type);
}
}
return markup;
}
function getHTML(data) {
var markup = '<table>';
markup += '<tr class="odd">' + getRowHTML(data,'size') + '</tr>';
markup += '<tr class="even">' + getRowHTML(data,'price') + '</tr>';
markup += '<tr class="odd">' + getRowHTML(data,'type') + '</tr>';
markup += '</table>';
return markup;
}
Tout fonctionne bien jusqu'à ce que j'ajouter le contrôle des enfants et l'appel de fonction récursif correspondant.
Ensuite, le résultat est les deux premiers objets et les enfants, mais le dernier ne sera pas dans la table. Des idées?
Merci, j'ai raté le global. Le code réel est beaucoup plus complexe et le JSON proviendra d'une source sécurisée. Mais merci pour l'indice aussi. – dantz
Tellement mieux que ce que je piratais. Je préfère retourner les données X et Y, mais pour ce dont j'ai besoin en ce moment, c'est parfait. – Jan