入住此的jsfiddle分别返回不同的结果为Chrome和Firefox:http://jsfiddle.net/9aE2p/1/hasChildNodes()在Chrome和Firefox
而且,这里粘贴相同的代码:
var xmlStr = '<?xml version="1.0" encoding="UTF-8"?><abc abc_attr="abc_attr_value"><abc_child abc_child_attr="abc_child_attr_value1"/><abc_child abc_child_attr="abc_child_attr_value2"/></abc>';
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlStr, "text/xml");
var path = 'abc/@abc_attr';
var nodes = xmlDoc.evaluate(path, xmlDoc, null, XPathResult.ANY_TYPE, null);
var result = nodes.iterateNext();
while (result) {
var textContent = '<BR>result.textContent: "' + result.textContent + '"';
var nodeType = '<BR>result.nodeType: "' + result.nodeType + '"';
var resultHasChildren = '<BR>result.hasChildNodes(): ' + result.hasChildNodes();
document.write(nodeType);
document.write(textContent);
document.write(resultHasChildren);
result = nodes.iterateNext();
}
我所注意到的是, hasChildNodes()对于Firefox返回false,对于Chrome则返回true。
如果nodeType是属性节点,那么在Chrome中它有一个具有实际值的子节点。 但在Firefox中,它没有任何子节点,并且该值存储在属性节点本身内。
我很想知道是否有关于这种细微差别的任何文档?
我已经检查了以下文件,但无法找到任何这样的细节:
https://developer.mozilla.org/en-US/docs/DOM/Node.hasChildNodes
http://www.w3.org/TR/2000/REC-DOM-Level-2-Core-20001113/core.html#ID-810594187
感兴趣的人之一,歌剧院赞同铬 – dmi3y
也许它与Webkit vs Gecko有关。 Opera是基于webkit的吗? – bits
nope,他们有自己的presto,猜想很老的 – dmi3y