BEA ホーム | 製品 | dev2dev | support | askBEA
 ドキュメントのダウンロード   サイト マップ   Glossary 
検索

WebLogic JSP Tag Extensions プログラマーズ ガイド

 Previous Next Contents Index PDF で侮ヲ  

JSP タグ拡張のプログラミングの概要

JSP 1.1 仕様には、JavaServer Pages(JSP)ページでカスタム タグを作成および使用するための機能が導入されました。カスタム タグは、Web ページ作成者が使いやすく管理しやすいように、Web ページのプレゼンテーションからビジネス ロジックの複雑さを分離するための優れた方法です。JSP ページでカスタム JSP タグ拡張を使用すると、動的コンテンツを生成できます。また、さまざまな Web 開発ツールを使用して、プレゼンテーションを作成できるようになります。

WebLogic Server は、JSP 1.1 仕様に定義されているタグ拡張メカニズムを完全にサポートしています。

以下の節では、JSP タグ拡張の概要を示します。

 


カスタム タグ機能の概要

カスタム JSP タグを作成するには、タグ ハンドラと呼ばれる Java クラスを作成します。タグ ハンドラは、以下のいずれかの方法で作成します。

抽象基本クラスを拡張すると、タグ ハンドラ クラスがそのインタフェース内のすべてのメソッドを実装する必要がなくなります。また、他の便利な機能を使用できるようになります。TagSupport クラスと BodyTagSupport クラスが Tag または BodyTag インタフェースを実装し、API に組み込まれます。

1 つまたは複数の JSP タグをタグ ライブラリに登録することができます。タグ ライブラリは、タグ ライブラリ記述子(TLD)ファイルによって定義されます。TLD は各タグの構文を記述し、その機能を実行する Java クラスにそのタグを関連付けます。

 


JSP でのカスタム タグの使い方

カスタム タグは、以下のタスクを実行できます。

カスタム タグのフォーマット

カスタム タグのフォーマットは、空タグと呼ばれる空のものか、または本体付きタグと呼ばれる本体を含むものです。どちらのタイプのタグも、そのタグを実装する Java クラスに渡される複数の属性を受け付けます。詳細については、タグ本体内の例外処理を参照してください。

空タグの形式は次のとおりです。

<mytaglib:newtag attr1="aaa" attr2="bbb" ... />

本体付きタグの形式は次のとおりです。

<mytaglib:newtag attr1="aaa" attr2="bbb" ... >
本体
</mytaglib:newtag>

タグ本体には、多くの JSP 構文、およびネストされた本体を持つ別のカスタム JSP タグを入れることができます。タグは、お互いの内部で任意のレベルにネストできます。次に例を示します。

<mytaglib:tagA>
<h2>これは tagA の本体です</h2>
このテキストはこれまでに <mytaglib:counter /> 回現れました !
<p>
<mytaglib:repeater repeat=4>
<p>Hello World!
</mytaglib:repeater>
</mytaglib:tagA>

上の例では、3 つのカスタム タグを使用して、本体付きタグの中にタグをネストする方法が示されています。これらのタグは、以下のように機能します。

サンプル シナリオ

以下のシナリオに、カスタム タグを使用して何ができるかを示します。

 


タグ ライブラリの参照

JSP タグ ライブラリは、タグ ライブラリ記述子 (tld) によって定義されます。JSP ページからカスタム タグ ライブラリを使用するには、以下のように <%@ taglib %> ディレクティブを使用してそのタグを参照します。次に例を示します。

  <%@ taglib uri="myTLD" prefix="mytaglib" %>

uri

JSP エンジンは、Web アプリケーション デプロイメント記述子(web.xml)<taglib-uri> 要素で定義し uri とこの uri 属性を照合することによって、タグ ライブラリ記述子ファイルを見つけようとします。たとえば、上の taglib ディレクティブの myTLD は、次のように Web アプリケーション デプロイメント記述子のタグ ライブラリ記述子 (library.tld) を参照します。

<taglib>
  <taglib-uri>myTLD</taglib-uri>
<taglib-location>library.tld</taglib-location>
</taglib>

prefix

prefix 属性は、タグ ライブラリにラベルを割り当てます。カスタム JSP タグを使用してページを作成する場合は、このラベルを使って関連するタグ ライブラリを参照します。たとえば、上の例のライブラリ(mytaglib)が newtag という新しいタグを定義した場合、このタグを JSP ページで使用するには、以下のように記述します。

<mytaglib:newtag>

詳細については、3-1 ページのタグ ライブラリ記述子の作成を参照してください。

 

Back to Top Previous Next