這篇文章主要介紹了XML中Node和Element區(qū)別是什么,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

1.元素(Element)和結(jié)點(diǎn)(Node)的區(qū)別,元素是一個(gè)小范圍的定義,必須是含有完整信息的結(jié)點(diǎn)才是一個(gè)元素,例如<p>...</p>。但是一個(gè)結(jié)點(diǎn)不一定是一個(gè)元素,而一個(gè)元素一定是一個(gè)結(jié)點(diǎn)。
什么是node:
NODE是相對TREE這種數(shù)據(jù)結(jié)構(gòu)而言的。TREE就是由NODE組成。這個(gè)部分你可以參考離散數(shù)學(xué)的樹圖。
什么是element
ELEMENT則是XML里的概念,<xxx>就是元素,是XML中的數(shù)據(jù)的組成部分之一。
素(Element)和結(jié)點(diǎn)(Node)的區(qū)別,元素是一個(gè)小范圍的定義,必須是含有完整信息的結(jié)點(diǎn)才是一個(gè)元素,例如<p>...</p>。但是一個(gè)結(jié)點(diǎn)不一定是一個(gè)元素,而一個(gè)元素一定是一個(gè)結(jié)點(diǎn)。
<a> <b> </b> <b> </b> <a>
DOM將文檔中的所有都看作節(jié)點(diǎn) node>element
1DOM在解析文檔的時(shí)候按整個(gè)文檔的結(jié)構(gòu)生成一棵樹,全部保存在內(nèi)存
優(yōu)點(diǎn)就是整個(gè)文檔都一直在內(nèi)存中,我們可以隨時(shí)訪問任何節(jié)點(diǎn),并且對樹的遍歷也是比較熟悉的操作;缺點(diǎn)則是耗內(nèi)存,并且必須等到所有的文檔都讀入內(nèi)存才能進(jìn)行處理。
2一個(gè)需要注意的地方就是,XML文檔兩個(gè)標(biāo)簽之間的空白也是這棵樹的一個(gè)節(jié)點(diǎn)(Text節(jié)點(diǎn))。 <a> <b></b> <a> a有三個(gè)節(jié)點(diǎn)
Element root = doc.getDocumentElement();:root是什么????
NodeList list = root.getChildNodes(); root 到底是節(jié)點(diǎn)還是元素我不清楚?????
node有幾個(gè)子類型:
Element,
Text,
Attribute,
RootElement,
Comment,
Namespace等Element是可以有屬性和子節(jié)點(diǎn)的node。
Element是從Node繼承的
//轉(zhuǎn)換 if (node.getNodeType() == Element.ELEMENT_NODE)
{ Element e = (Element) node; }元素有孩子嗎 ?
elemen et 性質(zhì)
1 e.getAttributes()
2 e.getChildNodes()
3 e.getTagName()
Element root = doc.getDocumentElement();:root是什么????
NodeList list = root.getChildNodes(); root 到底是節(jié)點(diǎn)還是元素我不清楚???
······················································
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);
}
}
}
}感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享XML中Node和Element區(qū)別是什么內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細(xì)的解決方法等著你來學(xué)習(xí)!
文章標(biāo)題:XML中Node和Element區(qū)別是什么-創(chuàng)新互聯(lián)
本文地址:http://www.chinadenli.net/article30/dcsppo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、搜索引擎優(yōu)化、網(wǎng)站維護(hù)、網(wǎng)站導(dǎo)航、自適應(yīng)網(wǎng)站、全網(wǎng)營銷推廣
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容