新聞中心
我想您一定對XML有所了解,說不定您現(xiàn)在還躍躍欲試想寫一段XML文本呢,可是現(xiàn)在能找到的跨平臺的、免費的XML編輯器太少了。所以在本文中,我想介紹一下或者說帶您一步一步的開發(fā)一個簡單的XML編輯器,當然我們要用到一些最常見的JTree Swing組件,不過這些都是免費的,有些是JDK中的,有些是可以從網(wǎng)上下載的。我想通過本文,你就可以創(chuàng)建一個屬于你自己的XML編輯器。

創(chuàng)新互聯(lián)建站:成立與2013年為各行業(yè)開拓出企業(yè)自己的“網(wǎng)站建設”服務,為上千余家公司企業(yè)提供了專業(yè)的成都網(wǎng)站設計、成都網(wǎng)站制作、網(wǎng)頁設計和網(wǎng)站推廣服務, 定制網(wǎng)站制作由設計師親自精心設計,設計的效果完全按照客戶的要求,并適當?shù)奶岢龊侠淼慕ㄗh,擁有的視覺效果,策劃師分析客戶的同行競爭對手,根據(jù)客戶的實際情況給出合理的網(wǎng)站構架,制作客戶同行業(yè)具有領先地位的。
先讓我介紹一下本文輯寫的思路。首先我想簡要的討論一下XML和為什么樹型結構比較適合用來顯示XML,然后我們來看一看JAXP API如何建立所需要的XML類的環(huán)境;然后我們將了解用來顯示一個圖形樹的JTree Swing組件;最后,我們將創(chuàng)建一個繼承JTree組件的可以重復使用的類,可以用來分析一個XML文檔,并把數(shù)據(jù)顯示在一個Jtree中。
說到XML(eXtensible Markup Languge),人們往往把它當成是一種新的用于Web瀏覽器中的標記語言,就象HTML或CSS一樣。其實,XML是一種數(shù)據(jù)表示語言,它允許你使用一種非常有效的方法來描述你的數(shù)據(jù)。XML能夠使你定義諸如“these three words constitutes a heading”這樣的語句。XML允許你聲明任何類型的數(shù)據(jù),而不是用來把這些數(shù)據(jù)顯示在網(wǎng)頁中。
請看一看下面的XML實例:
- <article>
- <header>
- <title>
- <subtitle> </subtitle>
- </title>
- <author> Wayne </author>
- <header>
- <content> </content>
- </article>
請注意,這些元素和標準的HTML語句是不同的,但是它們看上去比較象HTML,這是因為XML和HTML都是來源于SGML語言。不同的是HTML有預定義的標簽集,而XML的語法則有許多靈活性,它允許你使用表意的標記如< author>來括在數(shù)據(jù)兩邊。你還要注意,所有的元素都從屬于根元素(上例中為< article>),有些元素則還有自己的子元素,如< subtitle>就是< title>的子元素。這樣的數(shù)據(jù)組織方式有三個好處:數(shù)據(jù)能夠更加表意,數(shù)據(jù)更加易維護而且數(shù)據(jù)更加容易作為一個樹的結構表現(xiàn)出來,這就是我們?yōu)槭裁词褂肑Tree對象來顯示XML數(shù)據(jù)的原因。如果你想對XML有更深的了解,請參閱天極網(wǎng)上的相關教程。
JAXP是一個用于處理XML的Java API,它能夠使應用程序分析并且轉(zhuǎn)化XML文檔,它的功能有點象JDBC API,都是把函數(shù)功能抽象成一個個方法。你可以去Apache網(wǎng)站找到最新的Xerces分析器,其中含有最新的JAXP,下載下來以后把它放在你的類目錄中。
下面讓我們看一下如何使用JTree Swing組件。
我們都知道,在自然界中,一棵樹通常都有一個非常粗的樹干,樹干上有許多樹枝分叉。每個樹杈和樹杈之間都有一定的聯(lián)系,因為它們都有同一個來源:樹干。這種繼承的關系并不只在樹枝中有,人類譜系也遵循相同的規(guī)律。從父母,到子女再到子女的子女,就這樣直到數(shù)不清為止。同樣,在數(shù)據(jù)存儲中,樹的概念也是一種使用同人類家譜樹一樣方法儲存數(shù)據(jù)的方法。樹的每一個樹杈稱為一個節(jié)點,每個有子節(jié)點的節(jié)點稱為父節(jié)點,所有的子節(jié)點的公共的父節(jié)點被稱為根節(jié)點。一個JTree組件就是一個簡單的樹數(shù)據(jù)結構的可視化表現(xiàn)形式。
幾乎所有的XML編輯器都包括一個可視化的樹結構,能讓你編輯XML文檔中的元素。我們馬上就會構建一個編輯器,不過在此之前,先讓我們再了解一下JTree組件。一個節(jié)點在一棵樹的某個位置儲存數(shù)據(jù),為了存儲數(shù)據(jù),必須知道任何一個父節(jié)點和它們的子節(jié)點。javax.swing.tree包定義了一些非常有用的接口,提供了一種通用的方法構建和操作一個樹結構。
文章名稱:介紹JTreeSwing組件
網(wǎng)站URL:http://m.5511xx.com/article/cdpdpod.html


咨詢
建站咨詢
