我有以下代码,它接受来自xml的输入并创建一个无序列表。添加一个类到动态创建的列表元素
$(function() {
var map = function() {
if ($(this).is("parent")) {
var children = $(this).children().map(map).get().join('');
$(this).children().remove();
var result = "<li class='BGOfDiv'>" + $(this).text();
return result + "<ul>" + children + "</ul></li>";
}
if ($(this).is("Children")) {
return "<li class='BGOfDiv'>" + $(this).text() + "</li>";
}
};
$.get("test.xml", function(data) {
var result = $(data).map(map);
$("#org").html(result[0]);
$("#org").jOrgChart({
chartElement : '#chart',
dragAndDrop : false
});
dragNodes();
}, "html");
});
目前,我的XML看起来像这样
<?xml version="1.0" encoding="utf-8"?>
<Parent>Director
<Children>Exe Director1</Children>
<Children>Exe Director2</Children>
<Parent>Exe Director3
<Children>Sub Director 1</Children>
<Children>Sub Director 2</Children>
<Parent>Sub Director 3
<Children>Cameraman 1</Children>
<Children>Cameraman 2</Children>
</Parent>
</Parent>
</Parent>
然而,XML将作出一定的保持图像的,我需要申请为每个node.That背景图片的路径我的XML看起来像
<?xml version="1.0" encoding="utf-8"?>
<Parent>../images/1.jpg
<Children>../images/2.jpg</Children>
<Children>../images/3.jpg</Children>
<Parent>../images/4.jpg
<Children>../images/5.jpg</Children>
<Children>../images/6.jpg</Children>
<Parent>../images/7.jpg
<Children>../images/8.jpg</Children>
<Children>../images/9.jpg</Children>
</Parent>
</Parent>
</Parent>
我明白,我将需要使用的jquery
的.css
属性和设置background-image
当我创建的新<li>
元素,但我无法弄清楚如何做到这一点。
感谢您的期待。任何帮助将不胜感激。
这可能不是一个好主意,可以将您传递给'map','map'的回调函数命名。 – jbabey
@ jbabey:谢谢,会改变:) :) –