您的位置:首页 > Web前端 > Node.js

Node和Element的区别

2016-05-03 15:11 351 查看
今天在做ASP.NET操作XML文档的过程中,发现了两个类:XmlNode和XmlElement。这两个类的功能极其类似(因为我们一般都是在对Element节点进行操作)。上网搜罗了半天,千篇一律的答案。永远说不到重点,有些人回答又特别含糊,无奈之下,自己设断点尝试对比效果,现在总结如下:

1、通过继承关系XmlElement继承自XmlLinkedNode又继承自XmlNode类,由此可知XmlElement是XmlNode的子类。我们知道子类继承了父类所有的属性和方法,因此,XmlNode所拥有的方法和属性,在XmlElement类中也是可以使用的。

2、XmlElement是特殊的XmlNode类,Xml节点有多种类型:属性节点、注释节点、文本节点、元素节点等。也就是XmlNode是这多种节点的统称。但是XmlElement专门指的就是元素节点。

3、XmlElement是具现类,可以直接实例化,而XmlNode是抽象类,必须通过XmlDocument实例通过CreateNode创建。

4、XmlElement拥有众多对Attribute的操作方法,可以方便的对其属性进行读写操作(XmlNode也可以通过Attributes属性获取属性列表)。

5、在网上看到有人这么评论这两个类的区别:XmlNode包含子节点,XmlElement只包含属性及其本身不含有子节点。但是我通过代码测试,发现即使是XmlElement,也可以通过ChildNodes来获取子节点列表。虽然在断点中断模式下,我并没有发现XmlElement有ChildNodes属性。举例如下:

<Book img="aspnet.jpg"> //是XmlNode也是XmlElement,但是img以及aspnet.jpg只是XmlNode

<Name> //既是XmlNode 也是XmlElement

C# //只是XmlNode

</Name>

</Book>

也就是元素节点可以相应转换为XmlElement,这样既可以使用XmlNode的功能,也可以使用它特有的对属性的操作方法。

任意节点都可以使用XmlNode,因为XmlNode是所有Node的父类。

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()

Element root = doc.getDocumentElement();:root是什么????

NodeList list = root.getChildNodes(); root 到底是节点还是元素我不清楚???

······················································

public void domParse(String fileName) throws Exception {

DocumentBuilderFactory f = DocumentBuilderFactory.newInstance();

DocumentBuilder db = f.newDocumentBuilder();//builder

Document docment = db.parse(new File(fileName));//parese

Element el = docment.getDocumentElement();//root

domRead(el);

}

public void domRead(Element currentNode) {

if ("struts-config".equals(currentNode.getNodeName())) {

config = new StrutsConfig();

}

NodeList list = currentNode.getChildNodes();

for (int i = 0; i < list.getLength(); i++) {

Node node = list.item(i);

if (node.getNodeType() == Element.ELEMENT_NODE) {

Element e = (Element) node;//????

if ("form-beans".equals(e.getTagName())) {

formBeans = new ArrayList<FormBeanConfig>();

domRead(e);

}

if ("form-bean".equals(e.getTagName())) {

FormBeanConfig fc = new FormBeanConfig();

NamedNodeMap attrs = e.getAttributes();

for (int j = 0; j < attrs.getLength(); j++) {

Attr attr = (Attr) attrs.item(j);

if ("name".equals(attr.getName())) {

fc.setName(attr.getValue());

} else {

fc.setType(attr.getValue());

}

}

formBeans.add(fc);

}

if ("action-mapping".equals(e.getTagName())) {

actions = new ArrayList<ActionConfig>();

domRead(e);

}

if ("action".equals(e.getTagName())) {

ActionConfig ac = new ActionConfig();

NamedNodeMap attrs = e.getAttributes();

for (int k = 0; k < attrs.getLength(); k++) {

Attr attr = (Attr) attrs.item(k);

if ("path".equals(attr.getName())) {

ac.setPath(attr.getValue());

} else if ("type".equals(attr.getName())) {

ac.setType(attr.getValue());

} else {

ac.setName(attr.getValue());

}

}

actions.add(ac);

}

}

}

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: