Javascript Xpath and default namespaces(JavaScript XPath和默认命名空间)
本文介绍了JavaScript XPath和默认命名空间的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一些JavaScript/XPath,它不能像我预期的那样工作。(available on jsfiddle)似乎我对一个XML命名空间做了一些错误的事情,使我无法通过它们的节点(标记)名称查询元素。
如果我尝试查询当前节点的所有子节点,我发现元素myElement
没有问题:
var xpathResult = xmlDoc.evaluate( "child::*", rootElement, nsResolver, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null);
var queryEl;
if(queryEl = xpathResult.iterateNext()) {
alert("child::* found element " + queryEl.nodeName);
}
else {
alert("child::* found nothing!");
}
.但是,如果我专门以myElement
节点(标记)名称为目标节点,则不会得到任何结果:
/* Now try getting only those children with nodeName `myElement` */
xpathResult = xmlDoc.evaluate( "child::myElement", rootElement, nsResolver, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null);
var queryEl;
if(queryEl = xpathResult.iterateNext()) {
alert("child::myElement found element " + queryEl.nodeName);
}
else {
alert("child::myElement found nothing!");
}
我做错了什么?
推荐答案
尝试将此作为您的解析程序:
var nsResolver = (function (element) {
var
nsResolver = element.ownerDocument.createNSResolver(element),
defaultNamespace = element.getAttribute('xmlns');
return function (prefix) {
return nsResolver.lookupNamespaceURI(prefix) || defaultNamespace;
};
} (xmlDoc.documentElement));
您还必须选择如下元素:
"child::default:myElement"
// where 'default' can be anything, as long as there is a namespace
进一步阅读:
- https://developer.mozilla.org/en/DOM/document.createNSResolver
- https://developer.mozilla.org/en/Introduction_to_using_XPath_in_JavaScript(=>实现默认命名空间解析器)
- http://www.w3.org/TR/DOM-Level-3-XPath/xpath.html#XPathNSResolver-lookupNamespaceURI
您的小提琴:http://jsfiddle.net/chKZc/5/(更新)
这篇关于JavaScript XPath和默认命名空间的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:JavaScript XPath和默认命名空间
基础教程推荐
猜你喜欢
- 如何使用TypeScrip将固定承诺数组中的项设置为可选 2022-01-01
- 用于 Twitter 小部件宽度的 HTML/CSS 2022-01-01
- 如何使用JIT在顺风css中使用布局变体? 2022-01-01
- 我可以在浏览器中与Babel一起使用ES模块,而不捆绑我的代码吗? 2022-01-01
- 自定义 XMLHttpRequest.prototype.open 2022-01-01
- Chart.js 在线性图表上拖动点 2022-01-01
- 直接将值设置为滑块 2022-01-01
- Vue 3 – <过渡>渲染不能动画的非元素根节点 2022-01-01
- Electron 将 Node.js 和 Chromium 上下文结合起来意味着 2022-01-01
- html表格如何通过更改悬停边框来突出显示列? 2022-01-01