0

我有这样的 XML 文件

<?xml version="1.0" encoding="ISO-8859-1"?>
<childrens>
  <child id="1" value="Root Catalog" parent_id="0">
    <child id="2" value="Apparel" parent_id="1">
      <child id="4" value="Shirts" parent_id="2"/>
      <child id="5" value="Pants" parent_id="2"/>
    </child>
    <child id="3" value="Accessories" parent_id="1">
      <child id="6" value="Handbags" parent_id="3"/>
      <child id="7" value="Jewelry" parent_id="3"/>
    </child>
     .
     .
     .
    <child id='bla bla'>
       <child id='bla bla'>
           <child id="1005" value="test1" parent_is="1111"/>
           <child id="1006" value="test12" parent_is="1111"/>
           <child id="1007" value="test123" parent_is="1111"/>
        <child>
    </child>
  <child >
</childrens>

我已经编写了这个 jQuery 代码来获取叶子元素(没有子元素),例如这里的叶子节点是 id 4,5,6,7,1005,1006 和 1007

$.ajax({
    type: "GET",
    url: "test.xml",
    dataType: "xml",
    success: function(xml) {
        $(xml).find('child').children().each(function(){
            var id = $(this).attr('entity_id');
            alert(id)
        });
    }
});

它不工作

4

1 回答 1

1

如果您只想选择child“叶节点”且没有任何子节点的元素,您可以使用:empty选择器并将您的选择更改为:

find('child:empty')

然后通过删除迭代选定的元素,而不是它的子元素.children()

您的示例 XML 没有任何名为entity_id. 对于示例 XML,您将选择attr('id').

$.ajax({
    type: "GET",
    url: "test.xml",
    dataType: "xml",
    success: function(xml) {
        $(xml).find('child:empty').each(function(){
            var id = $(this).attr('id');
            alert(id)
        });
    }
});
于 2013-01-26T15:13:29.300 回答