无论出于什么原因,如果我输入源XML,evaluate会做它的事情。但是,如果我使用样式表转换XML,并且它是DocumentFragment,它就会进入警报("no"(。有人知道会发生什么吗?在运行evaluate之前,可能需要转换DocumentFragment?但是去了什么?非常感谢。
doc_trans=xsltProcessor.transformToFragment(doc_xml_source, document);
//var resultDoc=doc_xnl_source;
var resultDoc=doc_trans;
//var path = "/catalog/cd/title"
path="/html/body/table//row";
if (resultDoc.evaluate) {
alert("yes");
var nodes = rDoc.evaluate(path, resultDoc, null, XPathResult.ANY_TYPE, null);
var result = nodes.iterateNext();
while (result) {
alert(result.childNodes[0].nodeValue);
txt += result.childNodes[0].nodeValue + "<br>";
result = nodes.iterateNext();
}
} else {
alert("no");
var evaluator = new XPathEvaluator();
//DocumentFragment not a valid node type exception thrown here...
var resulty = evaluator.evaluate("//tbody/tr", resultDoc, null,
XPathResult.ORDERED_NODE_SNAPSHOT_TYPE);
alert( resulty.snapshotLength);
}
尝试使用XPathEvaluator.evaluate()
https://developer.mozilla.org/en-US/docs/Web/API/XPathEvaluator/evaluate
我也尝试过将DocumentFragment(resultDoc(转换为HTML元素(zz(。。。
var zz=document.createElement("div2");
zz.appendChild(resultDoc);
var evaluator = new XPathEvaluator();
var resulty = evaluator.evaluate("//tbody/tr", zz, null,
XPathResult.ORDERED_NODE_SNAPSHOT_TYPE);
正在生成异常"TypeError:无法读取未定义的"的属性"snapshotLength";
DocumentFragment与NodeList共享大多数方法,因此querySelector和querySelectorAll、firstChild等方法与生成的DocumentFraction共享。
我想在转换后的文档(DocumentFragment(中查找行数,所以使用querySelector而不是evaluate。。。
var allDivs = resultDoc.querySelectorAll('tr');
alert(allDivs.length);