jqueryを使用してネストされたxmlドキュメントを順序付けられていないリストに変換しようとしています。xmlドキュメントは
<?xml version="1.0" encoding="utf-8"?>
<Parent>
<name>Director</name>
<Children>Exe Director1</Children>
<Children>Exe Director2</Children>
<Parent>
<name>Exe Director3</name>
<Children>Sub Director 1</Children>
<Children>Sub Director 2</Children>
<Parent>
<name>Sub Director 3</name>
<Children>Cameraman 1</Children>
<Children>Cameraman 2</Children>
</Parent>
</Parent>
</Parent>
期待される出力:
<ul>
<li>Director
<ul>
<li>Exe Director 1</li>
<li>Exe Director 2</li>
<li>Exe Director 3
<ul>
<li>Sub Director 1</li>
<li>Sub Director 2</li>
<li>Sub Director 3
<ul>
<li>Cameraman 1</li>
<li>Cameraman 2</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
私が得ている出力。
<ul>
<li>Director</li>
<ul>
<li>Exe Director1</li>
<li>Exe Director2</li>
<li>Exe Director3</li>
<ul>
<li>Sub Director 1</li>
<li>Sub Director 2</li>
<li>Sub Director 3</li>
<ul>
<li>Cameraman 1</li>
<li>Cameraman 2</li>
</ul>
</ul>
</ul>
</ul>
ご覧のとおり、子は親の内部ではなく、親li
の外部で作成されています。最新バージョンのコード
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Untitled Document</title>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript">
var levels;
$(document).ready(function()
{
$.ajax({
type: "GET",
url: "test.xml",
dataType: "xml",
success: function (xml) {
var $ul = xmlParser(xml, $('#ListContainer'));
}
});
});
function xmlParser(xml,ul) {
$(xml).contents().each(function (i, el)
{
if (el.nodeName.toUpperCase() == "CHILDREN")
{
$("<li>").text($(el).text()).appendTo($('ul:last')); // Append <li> Children
} else if (el.nodeName.toUpperCase() == "NAME")
{
$('<li>').text($(el).text()).appendTo(ul);
$('<ul>').insertAfter($("li:last"));
}
else if (el.nodeName.toUpperCase() == "PARENT")
{
if($('ul').length == 0)
{
ul = ul.append('<ul>');
}
ul.append(xmlParser($(el),$("ul:last") )); // Recursively append the other Parent
}
});
return ul;
}
</script>
</head>
<body>
<div id="ListContainer"></div>
</body>
</html>
私はこのコードに頭を悩ませています。何がうまくいかないかを手伝ってくれませんか。
ありがとう