微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

关于selectNodes与selectSingleNode的用法的区别

今天在网上看到一个关于selectNodes与selectSingleNode的用法的区别。

由于之前没有特别在意,因而今日看见是很是惊异。特复制过来,供大家一起学习!

中文中提到了最重要的区别是在运用操作后的变化。

selectnodes: selectNodes和ChildNodes获取XML内容数组的差异性

我们在使用XML进行查询或者变更数据的时候,需要注意两个很相近但结果相差很大的用法,如下:

1: XmlDocument doc = new XmlDocument();

2: Doc.loadXml(strXml);

3: XmlNodeList xnlListOne = doc.selectNodes(“//Nodes/Node”);

4: XmlNodeList xnlListTwo = doc.selectSingleNode(“//Nodes”).ChildNodes;

乍一看,xnlListOne和xnlListTwo都是获取当前Xml文档中的Node数组,如果我们没有变动该Xml文档,则两者没有任何不同,但是一旦我们在后面的操作中添加或者删除了其中的Node节点的话,情况就不一样了,变动后,当我们使用我们前面获取的xnlListOne和xnlListTwo进行遍历操作的时候,我们会发现,前者不会有任何变动,而后者会根据文档内容的变动而实时更新!

这个特性在前台页面的脚本中也会有所出现,例如div嵌套时,获取其嵌套子div时候,使用ChildNodes来获取也会实时更新,这个特性是因为他们都是通过指针指向操作其内容的,其内部应该伴随这一次遍历操作,而获取的结果数组是一次计算后的结果,已经通过开辟新内存的方式进行存储,故而不会受到影响,当然,我们也可以通过这个特性来做一些特别的功能

转自:http://www.2cto.com/kf/201007/52998.html

原文地址:https://www.jb51.cc/xml/298090.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。