zoukankan      html  css  js  c++  java
  • 转自别人的

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

     
    我们在使用XML进行查询或者变更数据的时候,需要注意两个很相近但结果相差很大的用法,如下:
    XmlDocument doc = new XmlDocument(); Doc.loadXml(strXml); XmlNodeList xnlListOne = doc.selectNodes(“//Nodes/Node”); XmlNodeList xnlListTwo = doc.selectSingleNode(“//Nodes”).ChildNodes;
    乍一看,xnlListOne和xnlListTwo都是获取当前Xml文档中的Node数组,如果我们没有变动该Xml文档,则两者没有任何不同,但是一旦我们在后面的操作中添加或者删除了其中的Node节点的话,情况就不一样了,变动后,当我们使用我们前面获取的xnlListOne和xnlListTwo进行遍历操作的时候,我们会发现,前者不会有任何变动,而后者会根据文档内容的变动而实时更新!
    这个特性在前台页面的脚本中也会有所出现,例如div嵌套时,获取其嵌套子div时候,使用ChildNodes来获取也会实时更新,这个特性是因为他们都是通过指针指向操作其内容的,其内部应该伴随这一次遍历操作,而获取的结果数组是一次计算后的结果,已经通过开辟新内存的方式进行存储,故而不会受到影响,当然,我们也可以通过这个特性来做一些特别的功能。
    菜鸟-潜水中
  • 相关阅读:
    [GEF]实现模板功能
    一篇WTP文章
    写代码的代码:JET
    投票选择eclipse.org的新界面
    在SWT里显示AWT对象
    Plugin.xml > Manifest.mf
    关于本体编程的实现
    一个用OWLS组装Web服务的例子
    感受Ruby on Rails
    通过OCP考试
  • 原文地址:https://www.cnblogs.com/C-CHERS/p/3908451.html
Copyright © 2011-2022 走看看