Как добавить несколько детей к родителю с помощью библиотеки Json2HTML
Я хочу добавить несколько детей к родителю, используя json2html.
jsonTestSuiteTemplate={
"testSuiteNames": [{"testSuiteName": "TS1"}],
};
var testSuiteHtmlTemplate = {
"tag": "table",
"border":"0",
"children": [{"tag": "tr",
"children": [{
"tag": "td",
"children": [{
"tag": "ul",
"class": "report",
"children":[{
"tag":"LI",
"nowrap":"false",
"class":"closed",
"children":
[{
"tag":"a",
"href":"#testsuite",
"onclick":function(){ return toggle(this);},
"children":[{
"tag":"big",
"children":[{
"tag":"font",
"color":"green",
'html':"ts1 - TS (ok)"}
}] //End of font tag
}] //End of big tag
}], //End of Anchor Tag
{
"children":[{
"tag":"LI",
"nowrap":"false",
"class":"closed",
"children":
[{
"tag":"a",
"href":"#testsuite",
"onclick":function(){ return toggle(this);},
"children":[{
"tag":"big",
"children":[{
"tag":"font",
"color":"green",
'html':"t1 - TC (ok)"}
}] //End of font tag
}] //End of big tag
}]
}] //End of inner List
}
}] // End of Link tag
}] //End of UI tag
}] // End of TD tag
}] // End of TR tag
};
var result = json2html.transform(jsonTestSuiteTemplate, testSuiteHtmlTemplate);
HTML предоставлен библиотекой JSON2Html
<table border="0"><tr><td><ul class="report"><LI nowrap="false" class="closed"><LI nowrap="false" class="closed"><a href="#testsuite"><big><font color="green">TS1</font></big></a></LI></LI></ul></td></tr></table>
Но я хочу HTMl, как это:
<table border="0">
<tr>
<td>
<ul class="report">
<LI nowrap="true" class="closed">
<A HREF="#testsuite" onclick="toggle(this)"><big><font color="green">ts1 - TS (ok)</font></big></A> - 0:00:03.800
<ul>
<LI nowrap="true" class="closed">
<A HREF="#testcase" onclick="toggle(this)"><big><font color="green">t1 - TC (ok)</font></big></A> - 0:00:03.800
</LI>
</ul>
</LI>
</ul>
</td>
</tr>
</table>
</td>
</tr>
</table>
Я новичок в библиотеке json2Html, и мне трудно добавить нескольких детей к одному и тому же родителю. Любая помощь очень ценится!
2 ответа
Решение
Если у вас возникли проблемы со сборкой преобразования, попробуйте использовать построитель преобразования
JSON2HTML Transform Builder Перейдите на вкладку "Builder"
Вот преобразование, которое я получаю для вашего HTML, я отредактировал его, чтобы включить правильный синтаксис для событий jquery. Также, если вы используете события, обязательно включите плагин jquery jquery.json2html.js
{"tag":"table","border":"0","children":[
{"tag":"tbody","children":[
{"tag":"tr","children":[
{"tag":"td","children":[
{"tag":"ul","class":"report","children":[
{"tag":"li","nowrap":"true","class":"closed","children":[
{"tag":"a","href":"#testsuite","onclick":function(){toggle(this);},"children":[
{"tag":"big","children":[
{"tag":"font","color":"green","html":"ts1 - TS (ok)"}
]}
]},
{"tag":"ul","children":[
{"tag":"li","nowrap":"true","class":"closed","children":[
{"tag":"a","href":"#testcase","onclick":function(){toggle(this);},"children":[
{"tag":"big","children":[
{"tag":"font","color":"green","html":"t1 - TC (ok)"}
]}
]}
]}
]}
]}
]}
]}
]}
]}
]}
var jsonTestSuiteTemplate={
"testSuiteNames": [{"testSuiteName": "TS1"},
],
};
var testSuiteHtmlTemplate = {
"tag": "table",
"border":"0",
"children": [{"tag": "tr",
"children": [{
"tag": "td",
"children": [{
"tag": "ul",
"class": "report",
"children":[{
"tag":"LI",
"nowrap":"false",
"class":"closed",
"children":
[{ //First Child
"tag":"a",
"href":"#testsuite",
"onclick":function(){ return toggle(this);},
"children":[{
"tag":"big",
"children":[{
"tag":"font",
"color":"green",
'html':function()
{
return this.testSuiteName;
}
}] //End of font tag
}] //End of big tag
}]
}, //End of Anchor Tag and End of First Child
{ //Second child
"children":[{
"tag":"LI",
"nowrap":"false",
"class":"closed",
"children":
[{
"tag":"a",
"href":"#testsuite",
"onclick":function(){ return toggle(this);},
"children":[{
"tag":"big",
"children":[{
"tag":"font",
"color":"green",
'html':"t1 - TC (ok)"
}] //End of font tag
}] //End of big tag
}]
}] //End of inner List
} // Second child
] // End of Link tag
}] //End of UI tag
}] // End of TD tag
}] // End of TR tag
};