我有一个com.google.gwt.xml.client.Document对象形式的XML文档。由于Document类上没有提供“getElementsByTagNameNS”API,是否可以使用一些本机Javascript函数来实现相同的功能?
API应该采用两个参数 1 - 命名空间前缀。 2 - XML标记名称。
我需要这样做,因为如果XML标记具有名称空间前缀,则最近的Chrome更新(v60)不会返回Document.getElementsByTagName(“book”)的NodeList。
答案 0 :(得分:0)
c.g.g.xml从不支持名称空间,因此不适用于使用XML名称空间的文档。它还包装了本机对象,并且不提供任何访问权限。
如今,我认为API的浏览器支持几乎没有区别(例如IE6的情况并非如此),因此您最好重写代码以使用JsInterop而不是cggxml(请查看元素2,应该已经有了“映射”)
答案 1 :(得分:0)
我已经实现了getElementsByTagName
功能的快速而又脏的替代方案。它采用完全限定的标记名称,并返回具有完全标记名称的所有后代元素节点。
/**
* Builds a list of the descendant elements with the supplied tag name from the {@code parent} node. The result
* nodes are ordered by a depth-first traversal of the element graph.
*
* @param tag {@link String} = The tag we are looking for. Fully qualified with the namespace if present (e.g. {@code hh:label})
* @param parent {@link Node} = Root node of the search
* @return {@link List<Node>} = The node list
*/
public static List<Node> getElementsByTagName(String tag, Node parent) {
List<Node> result = new ArrayList<>();
if (parent == null) {
return result;
}
NodeList children = parent.getChildNodes();
for (int childIdx = 0; childIdx < children.getLength(); childIdx++) {
Node child = children.item(childIdx);
if (child.getNodeType() != Node.ELEMENT_NODE) {
continue;
}
if (((Element) child).getTagName() == tag) {
result.add(child);
}
getElementsByTagName(tag, child, result);
}
return result;
}
private static void getElementsByTagName(String tag, Node parent, List<Node> partialResult) {
if (parent == null) {
return;
}
NodeList children = parent.getChildNodes();
for (int childIdx = 0; childIdx < children.getLength(); childIdx++) {
Node child = children.item(childIdx);
if (child.getNodeType() != Node.ELEMENT_NODE) {
continue;
}
if (((Element) child).getTagName() == tag) {
partialResult.add(child);
}
getElementsByTagName(tag, child, partialResult);
}
}