dom编程

1.DOM解析器在解析XML文档时,会把文档中的所有元素,按照其出现的层次关系,解析成一个个Node对象(节点)。

2.在dom中,节点之间关系如下:
位于一个节点之上的节点是该节点的父节点(parent)
一个节点之下的节点是该节点的子节点(children)
同一层次,具有相同父节点的节点是兄弟节点(sibling)
一个节点的下一个层次的节点集合是节点后代(descendant)
父、祖父节点及所有位于节点上面的,都是节点的祖先(ancestor)

3.Node对象提供了一系列常量来代表结点的类型,当开发人员获得某个Node类型后,就可以把Node节点转换成相应的节点对象(Node的子类对象),以便于调用其特有的方法。(查看API文档)
Node对象提供了相应的方法去获得它的父结点或子结点。编程人员通过这些方法就可以读取整个XML文档的内容、或添加、修改、删除XML文档的内容了。

4.例子:
获得了一个document后:
Element student_node =document.createElement("student")
-------创建一个叫student的节点;

student_node.setAttribute("examid", student.getExamid());
-----向这个节点添加一个属性。

Element name_node = document.createElement("name");

name_node.setTextContent(student.getName());
---为这个属性节点设置一个属性值

student_node.appendChild(name_node);
----将name节点添加到他的父节点student——node上


document.getElementsByTagName("exam").item(0).appendChild(student_node);
--》通过getElementByTagName的方法获取到标签名为exam的所有的节点,然后取第一个节点,将student_node添加到上面。

问题:你懂这句话吗?
name_node.getParentNode().getParentNode().removeChild(name_node.getParentNode());

document对象还有很多方法,如得到属性值,等等。


你可能感兴趣的:(编程,xml)