我有一个这样的目录结构:
Root
|
|-Folder 1
| |
| |--Multiple files.
| |
| |--Folder 1.a
| |
|-Files |
|----Multiple files.
|----Further tree of more folder's and files.
它保存在 XML 文件中,如下所示:
<dir name="root">
<dir name="Folder 1">
<file name="file1"/>
<file name="file2"/>
<dir name="folder1.a>
<file name="innerfile"/>
</dir>
</dir>
<dir name="folder2">
.... so on ....
我想使用 jQuery 遍历这棵树并打印使用缩进的目录结构,如下所示:
Root
Folder1
file1
file2
Folder1.a
inner file
Folder2
file N
folder N
.....
我使用的代码如下
$(document).ready(function()
{
$.ajax({
type: "GET",
url: "root.xml",
dataType: "xml",
success: parseXml
});
});
function parseXml(xml)
{
$(xml).find("directory").each(function(){
$("#output").append("<a href = \"" + $(this).attr("absolutePath") + "\">" + $(this).attr("name") + "</a><br>");
$(this).find("file").each(function()
{
$("#output").append(" <a href = \"" + $(this).attr("absolutePath") + "\">" + $(this).attr("name") + "</a><br>");
});
$('#output').append("<br>");
});
我的代码正在运行,但嵌套文件夹的文件是多余的,因为我多次打印子目录中的所有文件,我希望一个文件只列出一次,但不知道怎么可能???