javascript基础从小白到高手系列一千一十:命名空间支持

对于使用命名空间的XML 文档,必须告诉XPathEvaluator 命名空间信息,才能进行正确求值。
处理命名空间的方式有很多,看下面的示例XML 代码:

<?xml version="1.0" ?>

<wrox:books xmlns:wrox=“http://www.wrox.com/”>
wrox:book
wrox:titleProfessional JavaScript for Web Developers</wrox:title>
wrox:authorNicholas C. Zakas</wrox:author>
</wrox:book>
wrox:book
wrox:titleProfessional Ajax</wrox:title>
wrox:authorNicholas C. Zakas</wrox:author>
wrox:authorJeremy McPeak</wrox:author>
wrox:authorJoe Fawcett</wrox:author>
</wrox:book>
</wrox:books>
在这个XML 文档中,所有元素的命名空间都属于http://www.wrox.com/,都以wrox 前缀标识。如
果想使用XPath 查询该文档,就需要指定使用的命名空间,否则求值会失败。
第一种处理命名空间的方式是通过createNSResolver()方法创建XPathNSResolver 对象。这
个方法只接收一个参数,即包含命名空间定义的文档节点。对上面的例子而言,这个节点就是document
元素wrox:books,其xmlns 属性定义了命名空间。为此,可以将该节点传给createNSResolver(),
然后得到的结果就可以在evaluate()方法中使用:
let nsresolver = xmldom.createNSResolver(xmldom.documentElement);
let result = xmldom.evaluate(“wrox:book/wrox:author”,
xmldom.documentElement, nsresolver,
XPathResult.ORDERED_NODE_SNAPSHOT_TYPE, null);
console.log(result.snapshotLength);
把nsresolver 传给evaluate()之后,可以确保XPath 表达式中使用的wrox 前缀能够被正确理
解。假如不使用XPathNSResolver,同样的表达式就会导致错误。
第二种处理命名空间的方式是定义一个接收命名空间前缀并返回相应URI 的函数,如下所示:
let nsresolver = function(prefix) {
switch(prefix) {
case “wrox”: return “http://www.wrox.com/”;
// 其他前缀及返回值
}
};
let result = xmldom.evaluate(“count(wrox:book/wrox:author)”,
xmldom.documentElement, nsresolver, XPathResult.NUMBER_TYPE, null);
console.log(result.numberValue);
在并不知晓文档的哪个节点包含命名空间定义时,可以采用这种定义命名空间解析函数的方式。只
要知道前缀和URI,就可以定义这样一个函数,然后把它作为第三个参数传给evaluate()。
浏览器对XSLT 的支持
可扩展样式表语言转换(XSLT,Extensible Stylesheet Language Transformations)是与XML 相伴的
一种技术,可以利用XPath 将一种文档表示转换为另一种文档表示。与XML 和XPath 不同,XSLT 没有
与之相关的正式API,正式的DOM 中也没有涵盖它。因此浏览器都以自己的方式实现XSLT。率先在
JavaScript 中支持XSLT 的是IE。

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值