DOM学习

W3C制定了一套XML分析器的标准接口规范---DOM,除此之外,其他机构也制定了一套接口规范---SAX.

 

xml文档--->xml分析器--->接口(DOM或者SAX)--->XML应用程序.

 

DOM 由三部分组成:核心(core),html和xml.

核心部分是结构化文档比较底层对象的集合,这一部分所定义的对象已经完全可以表达出任何

HTML和XML文档中的数据.

 

在DOM接口规范中,有四个基本的接口:Document,Node,NodeList,NamedNodeMap.

document接口是对文档进行操作的入口,它是从node接口继承过来的.

node接口是其他大多数接口的父类.

nodeList接口是一个节点的集合,包含了某个节点的所有子节点.

namedNodeMap接口也是一个节点的集合,通过该接口,可以建立节点名和节点之间一一映射关系.

 

------------------------------------***感谢风中叶老师视频指导***---------------------------------------------

 

利用DOM将xml文件打印出来的代码.

public class ViewXml {

 static String xmlStr = "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n";
 public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {

         DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
         DocumentBuilder db = dbf.newDocumentBuilder();
         Document document = db.parse("src/DOM/one.xml");
         Element de =  document.getDocumentElement();
        
         doXml(de);
        
         System.out.println(xmlStr);
 }

    private static void doXml(Element de){
     xmlStr = xmlStr + "<" + de.getNodeName();
     
     if(de.hasAttributes()){
      NamedNodeMap nnm = de.getAttributes();
      for(int i=0;i<nnm.getLength();i++){
       Node node = nnm.item(i);

       xmlStr = xmlStr + " " + node.getNodeName() + "=\"" + node.getNodeValue() + "\"";
      }
     }
     xmlStr = xmlStr + ">";
     
     NodeList nlist = de.getChildNodes();
     for(int i=0;i<nlist.getLength();i++){
      Node node = nlist.item(i);
      if(node.getNodeType() == Node.ELEMENT_NODE){
       doXml((Element)node);
      }else if(node.getNodeType() == Node.TEXT_NODE){
       xmlStr = xmlStr + node.getNodeValue();
      }
     }

     xmlStr = xmlStr + "</" + de.getNodeName() + ">";
    }
}

 

 

你可能感兴趣的:(dom)