zoukankan      html  css  js  c++  java
  • XML中元素和节点的区别

    XML中元素和节点的区别

     

    XML元素和结点的区别:

    1、区别介绍

    ElementNode的扩展,所以也更实用一些。例如,用Element可以方便的获得Node的属性getAttribute(String attrName)如果用Node,可以得到一个属性集,还要进一步检索才可得到想要的属性。一个结点不一定是一个元素,而一个元素一定是一个结点

    Element是Node的子集,XmlNode表示一个节点,包括XmlElement(元素)和XmlAttribute(属性)等。 如:

    <Alarm lock="true">             //node  
          <Time>                       //node  
              StringValue              //node  
          </Time>                      //node  
    </Alarm>                           //node  
      以上Alarm(元素节点),lock(属性节点),Time(元素节点),StringValue(文本节点)都是Node,但是只有 <Alarm>......</Alarm><Time>StringValue</Time>Element  

     

    2、具体功能实现

    2.1如果我想取得一个Node中的Attribute,那该怎么实现呢? 即:

      

      <root>  

              <data   id=data1   name=mydata></data>  

      </root>  

       

      怎样将data中的   id,name及其值取出来?

    问题解释

    两种方式:  
      1.先取得node  
      String   strID   =   node.getAttributes().getNamedItem("id").getNodeValue();  
      String   strName   =   node.getAttributes().getNamedItem("name").getNodeValue();  
      2.先取得element  
      String   strID   =   element.getAttribute("id");  
      String   strName   =   element.getAttribute("name");

    2.2、我想使用一个通用的方法,将一个Element中的所有属性取出来!但事先我不知道该Element有多少个属性,并且不知道每个属性的name是什么!

    问题解释

    先取得node  
      NamedNodeMap   nnm   =   node.getAttributes();  
      for(int   i=0   ;   i<nnm.getLength()   ;   i++)  
      {  
      System.out.println(nnm.item(i).getNodeName());  
      System.out.println(nnm.item(i).getNodeValue());  
      }


                                                               
          1.元素(Element)和结点(Node)的区别,元素是一个小范围的定义,必须是含有完整信息的结点才是一个元素,例如<div>...</div>。但是一个结点不一定是一个元素,而一个元素一定是一个结点。
    什么是node:
     
     
     
    NODE是相对TREE这种数据结构而言的。TREE就是由NODE组成。这个部分你可以参考离散数学的树图。
     
    什么是element
     
    ELEMENT则是XML里的概念,<xxx>就是元素,是XML中的数据的组成部分之一。
     
    素(Element)和结点(Node)的区别,元素是一个小范围的定义,必须是含有完整信息的结点才是一个元素,例如<div>...</div>。但是一个结点不一定是一个元素,而一个元素一定是一个结点。
     
    <a>
     
      <b> </b>
     
      <b> </b>
     
    <a>
     
    DOM将文档中的所有都看作节点 node>element
     
    1DOM在解析文档的时候按整个文档的结构生成一棵树,全部保存在内存
     
    优点就是整个文档都一直在内存中,我们可以随时访问任何节点,并且对树的遍历也是比较熟悉的操作;缺点则是耗内存,并且必须等到所有的文档都读入内存才能进行处理。
    2一个需要注意的地方就是,XML文档两个标签之间的空白也是这棵树的一个节点(Text节点)。 <a> <b></b> <a> a有三个节点
     
    Element root = doc.getDocumentElement();:root是什么????
     
    NodeList list = root.getChildNodes();             root 到底是节点还是元素我不清楚?????
     

    node有几个子类型:
     
        Element,

          Text,

        Attribute,

      RootElement,

        Comment,

        Namespace等
    Element是可以有属性和子节点的node。
     

    Element是从Node继承的
     
    //转换
     
    if (node.getNodeType() == Element.ELEMENT_NODE)

    {
         Element e = (Element) node; 
     
    }
     
     
     
     ?元素有孩子吗
     
    elemen et 性质
     
    1 e.getAttributes()

    2 e.getChildNodes()
     
    3 e.getTagName()

  • 相关阅读:
    1029: [JSOI2007]建筑抢修
    1028: [JSOI2007]麻将
    1050 棋盘染色 2
    1026: [SCOI2009]windy数
    1074: [SCOI2007]折纸origami
    839. Optimal Marks
    1024: [SCOI2009]生日快乐
    1025: [SCOI2009]游戏
    1023: [SHOI2008]cactus仙人掌图
    对前面的总结
  • 原文地址:https://www.cnblogs.com/handsome1013/p/10058838.html
Copyright © 2011-2022 走看看