<content> これは本文です</content>
</article>
これらの要素は標準の HTML ステートメントとは異なりますが、見た目は HTML に近いことに注意してください。 XML と HTML は両方とも SGML 言語から派生したものであるためです。違いは、HTML には事前定義されたタグのセットがあるのに対し、XML の構文には柔軟性があり、
JAXP は XML を処理するための Java API であり、アプリケーションが XML ドキュメントを分析および変換できるようにします。その機能は関数をメソッドに抽象化する JDBC API に似ています。 Apache Web サイトにアクセスして、最新の JAXP を含む最新の Xerces アナライザーを見つけてください。ダウンロード後、クラス ディレクトリに置きます。
JTree Swing コンポーネントの使用方法を見てみましょう。
自然界では、通常、木には非常に太い幹があり、多くの枝が枝分かれしていることは誰もが知っています。木の各枝と枝の間には、すべて同じ源である幹があるため、一定のつながりがあります。この継続的な関係は枝に限定されるものではなく、人間の系図も同じパターンに従います。親から子へ、子の子へ、数えきれないほど続きます。同様に、データ ストレージにおいて、ツリーの概念は、人間の家系図と同じ方法でデータを保存する方法です。ツリーの各ブランチはノードと呼ばれ、子ノードを持つ各ノードは親ノードと呼ばれ、すべての子ノードに共通の親ノードはルート ノードと呼ばれます。 JTree コンポーネントは、ツリー データ構造を単純に視覚的に表現したものです。
ほとんどすべての XML エディターには、XML ドキュメント内の要素を編集できる視覚的なツリー構造が含まれています。すぐにエディターを構築しますが、その前に、JTree コンポーネントを見てみましょう。ノードはツリー内の特定の場所にデータを保存します。データを保存するには、親ノードとその子ノードがわかっている必要があります。 javax.swing.tree パッケージは、ツリー構造を構築および操作するための共通の方法を提供する、いくつかの非常に便利なインターフェイスを定義します。
TreeNodeメソッドは、ツリーノード情報にアクセスするために使用されます
MutableTreeNodeメソッドは、可変ツリーで使用されます(子ノードを追加または削除できます)
TreeModelメソッドは、ツリー関連のデータモデルを作成および管理するために使用されます。
次に、JTree を継承し、ビジュアルな JTree コンポーネントを使用して XML ドキュメントを解析し、ノードを表示する機能を提供するクラスを作成します。
XTreeコンポーネントの作成
簡素化のため、コンポーネントはXtreeを構築することしかできず、ツリーの作成後にそのノードを処理することはできません。このクラスを見てみましょう。
Field:
PRivate DefaultMutableTreeNode TreeNode このメンバー変数には、JTree モデルを格納するために使用される TreeNode オブジェクトが格納されます。
DefaultMutableTreeNode クラスは javax.swing.tree で定義され、デフォルトで MutableTreeNode インターフェースの実装を提供します。
private DocumentBuilderFactory dbf
private DocumentBuilder db
private Document doc これら 3 つのメンバー変数は JAXP の一部であり、XML テキストを分析して DOM (Document Object Model) オブジェクトに変換するために使用されます。
Constructor
public XTree(String text)
このコンストラクターは、コンストラクターに渡されたXMLテキストを使用してXTreeオブジェクトを作成します。 JTree スーパークラスと DOM 分析オブジェクトに関連するいくつかの基本的な表示プロパティを初期化した後、コンストラクターは実際のビジュアル ツリーの作成に使用される TreeModel オブジェクトを生成します。 DOM オブジェクトを createTreeNode() メソッドに渡すことによって、ルート ノードを作成します。createTreeNode() メソッドは、DefaultMutableTreeNode 型のオブジェクトを返します。このオブジェクトは、ツリーの TreeModel を作成するために使用されます。
メソッド
private DefaultMutableTreeNode createTreeNode(Node root)
このメソッドは DOM ノードを取得し、すべてのノードが DefaultMutableTreeNode に追加されるまで子ノードを再帰的に処理します。これは再帰的なメソッドであり、ルート ノードの下にあるすべての子ノードを見つけるために、毎回自分自身を呼び出します。 JTree は、すでにツリーになっている DefaultMutableTreeNode オブジェクトを使用できます。
private String getNodeType(Node node)
このメソッドは、文字列を特定のタイプのノードに関連付けるために createTreeNode() によって使用されます。
private Node parseXml()
このメソッドは、XML テキスト文字列を解析するために使用され、Node 型のオブジェクトを返し、createTreeNode() メソッドに渡すことができます。
誰もが分析して研究できるように、以下の Java コードを提供しました。
// W3C の DOM クラスを入力します
import org.w3c.dom.*;
// DOM I/O 用の JAXP のクラス
import javax.xml.parsers.*;
// 標準 Java クラス
import javax.swing. *;
import javax.swing.tree.*;
import javax.swing.event.*;
import java.awt.*;
import java.awt.event.*;
import java.io .*;
public class
/**
* このメンバー変数には、JTree モデルを格納するために使用される TreeNode オブジェクトが格納されます。
*DefaultMutableTreeNode クラスは javax.swing.tree で定義されます
*MutableTreeNode インターフェースの実装はデフォルトで提供されます。
*/
public ( true );
setEditable( false ); // ツリーを編集可能にします
// DOM を初期化してオブジェクトを分析します
dbf = DocumentBuilderFactory.newInstance() ;
dbf.setValidating( false );
db = dbf. newDocumentBuilder();
// DOM ルート ノードを取得して JTree ツリー モデルに変換します
treeNode = createTreeNode( parseXml( text ) );
setModel( new DefaultTreeModel(treeNode ) );
} file://Abort XTree ()
/**
* これら 3 つのメンバー変数は JAXP の一部であり、XML テキストを分析して DOM (Document Object Model) オブジェクトに変換するために使用されます。
*/
private DefaultMutableTreeNode createTreeNode( Node root )
{
DefaultMutableTreeNode TreeNode = null;
文字列型、名前、値;
NamedNodeMap attribs;
Node attribNode;
// from ルートノードからデータを取得します
type = getNodeType( root );
name = root.getNodeName();
treeNode = new DefaultMutableTreeNode( root.getNodeType() == Node.TEXT_NODE ? value : name );
//属性の表示
attribs = root.getAttributes();
if( attribs != null )
{
for( int i = 0; i {
attribNode = attribs.item(i);
name = attribNode.getNodeName().trim();
value = attribNode.getNodeValue().trim();
if ( value != null )
{
if ( value .length() > 0 )
{
treeNode.add( new DefaultMutableTreeNode( "[属性] --> " + 名前 + "="" + 値 + """ ) );
} file://end if ( value.length() > 0 )
} file://end if ( value != null )
} file://end for( int i = 0; i } file://end if( attribs != null )
// 子ノードがある場合は再帰
if( root.hasChildNodes() )
{
NodeList Children;
int numChildren;
Node node;
String data;
children = root.getChildNodes();
/ / 子ノードが空でない場合は、再帰のみ
if(children != null )
{
numChildren = Children.getLength();
for (int i=0; i {
node = item(i);
if(node != null )
{
if(node.getNodeType() == Node.ELEMENT_NODE )
{
treeNode.add( createTreeNode(node) );
} file:// end if (node.getNodeType() == Node.ELEMENT_NODE )
data = node.getNodeValue();
if( data != null )
{
data = data.trim();
if ( !data. equals( " ") && !data.equals("