這篇文章主要介紹了XML中Node和Element區(qū)別是什么,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)建站從2013年成立,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目成都網(wǎng)站設計、成都網(wǎng)站建設網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元平樂做網(wǎng)站,已為上家服務,為平樂各地企業(yè)和個人服務,聯(lián)系電話:028-86922220
1.元素(Element)和結點(Node)的區(qū)別,元素是一個小范圍的定義,必須是含有完整信息的結點才是一個元素,例如<p>...</p>。但是一個結點不一定是一個元素,而一個元素一定是一個結點。
什么是node:
NODE是相對TREE這種數(shù)據(jù)結構而言的。TREE就是由NODE組成。這個部分你可以參考離散數(shù)學的樹圖。
什么是element
ELEMENT則是XML里的概念,<xxx>就是元素,是XML中的數(shù)據(jù)的組成部分之一。
素(Element)和結點(Node)的區(qū)別,元素是一個小范圍的定義,必須是含有完整信息的結點才是一個元素,例如<p>...</p>。但是一個結點不一定是一個元素,而一個元素一定是一個結點。
<a> <b> </b> <b> </b> <a>
DOM將文檔中的所有都看作節(jié)點 node>element
1DOM在解析文檔的時候按整個文檔的結構生成一棵樹,全部保存在內(nèi)存
優(yōu)點就是整個文檔都一直在內(nèi)存中,我們可以隨時訪問任何節(jié)點,并且對樹的遍歷也是比較熟悉的操作;缺點則是耗內(nèi)存,并且必須等到所有的文檔都讀入內(nèi)存才能進行處理。
2一個需要注意的地方就是,XML文檔兩個標簽之間的空白也是這棵樹的一個節(jié)點(Text節(jié)點)。 <a> <b></b> <a> a有三個節(jié)點
Element root = doc.getDocumentElement();:root是什么????
NodeList list = root.getChildNodes(); root 到底是節(jié)點還是元素我不清楚?????
node有幾個子類型:
Element, Text, Attribute, RootElement, Comment, Namespace等
Element是可以有屬性和子節(jié)點的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é)點還是元素我不清楚???
······················································
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); } } } }
感謝你能夠認真閱讀完這篇文章,希望小編分享XML中Node和Element區(qū)別是什么內(nèi)容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細的解決方法等著你來學習!
當前名稱:XML中Node和Element區(qū)別是什么
文章位置:http://www.rwnh.cn/article18/jdcpdp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、移動網(wǎng)站建設、網(wǎng)站排名、動態(tài)網(wǎng)站、云服務器、網(wǎng)頁設計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)