我正在尝试删除使用E4X javascript需要实现的具有空值的XML属性。请帮帮我。 代码:
function xmlparse(xml) {
var children = xml.*, attributes = xml.@*, length = children.length();
for each (var child in children) {
if(child.hasComplexContent())
{
for each (var chi in child.children()) {
var c= chi.localName()
if(chi.hasSimpleContent())
{
if(chi.@value == "")
{
delete chi
}
}
}
var obj = xmlparse(child)
}
}
}
输入:
<Test>
<id value="123"/>
<Book>
<source>
<English>
<bookid value=""/>
<version>
<type>
<place>
<author value="Test123"/>
<index value="10"/>
<display value=""/>
</place>
</type>
</version>
</English>
</source>
</Book>
<Book>
<source>
<German>
<bookid value=""/>
<version>
<type>
<place>
<author value="Test143"/>
<index value=""/>
<display value="Helo"/>
</place>
</type>
</version>
</German>
</source>
</Book>
</Test>
预期产出:
<Test>
<id value="123"/>
<Book>
<source>
<English>
<version>
<type>
<place>
<author value="Test123"/>
<index value="10"/>
</place>
</type>
</version>
</English>
</source>
</Book>
<Book>
<source>
<German>
<version>
<type>
<place>
<author value="Test143"/>
<display value="Helo"/>
</place>
</type>
</version>
</German>
</source>
</Book>
</Test>
通常,我需要从XML中删除空标记的值。 请指导我,我尝试了一些它不适合我的示例代码。
答案 0 :(得分:0)
由于要对每个xml节点执行相同的检查,因此无需递归地遍历它们。后代方法将一次获得所有这些。检查子项的hasSimpleContent方法可确保其没有子元素。
function deleteEmptyElements(xml) {
for each (var child in xml.descendants()) {
if (child.hasSimpleContent() && child.@value.toString() == '') {
delete child[0];
}
}
}