RichFaces-クイックガイド
RichFacesは、JSFテクノロジー用のオープンソースコンポーネントライブラリです。これはJBossによって開発および設計されています。RichFacesは、フロントエンドの予備知識がなくても、JSF開発者に再利用可能なマークアップとAJAX機能を提供します。RichFacesはJSF2上で開発されたため、JSFと同じライフサイクルに従います。組み込みのAJAXサポートとカスタマイズ可能なルックアンドフィール機能により、エンタープライズJavaアプリケーションの新たな地平が可能になりました。
長所と短所
以下はいくつかです advantages RichFacesを使用する方法。
AJAX support− RichFacesは、古い定型のAJAX、JavaScriptコードを削除して、Webページにマークアップを含めます。RichFacesを使用すると、開発者はAJAXの予備知識がなくても、オンザフライでマークアップを含めることができます。
Component Development Kit (CDK)−前述のように、開発者はアプリケーションで使用されるマークアップに集中する必要はありません。含める必要があるのは、これらの機能を使用するためのRichFacesタグだけです。このマークアップの自動作成は、CDKと呼ばれるランタイム環境によって実行されます。
Resource handling − RichFacesは、画像、Excel、スプレッドシートなどのさまざまなバイナリファイルを作成するための追加サポートを提供します。
Skinning−スキニングは、JSFで導入された最新のアプローチであり、アプリケーションのルックアンドフィールを非常に簡単に制御できます。他のさまざまなカスタマイズ可能なパラメーターを使用した特別に一元化されたカラーマネジメントにより、開発者にとって非常に便利です。
以下はいくつかです disadvantages RichFacesを使用する方法。
Resource −これはかなり新しいテクノロジーであるため、高品質のリソースを取得することは、金持ちの開発者にとって大きな問題です。
Complex−さまざまなフェーズを経て移行し、動的マークアップを作成することは、CDKの全責任です。CDKの内部処理を理解することは、従来のフロントエンド開発者にとって少し複雑で混乱を招きます。
この章では、RichFaces開発を続行できるように、開発環境をセットアップし、システムを構成します。
技術要件
技術要件に従って、JDK、アプリケーションサーバー、または任意のIDEを構成する方法を学習します。
システム要求
実行中のシステムを使用できます。メモリ、RAM、オペレーティングシステムに制限はありません。
JDKのインストール
先に進む前に、システムでJDKを構成しておく必要があります。JDK 7以降のバージョンをダウンロードしてインストールするには、オラクルの公式Webサイトを参照してください。正しく機能するように、Javaの環境変数を設定する必要がある場合があります。Windowsオペレーティングシステムへのインストールを確認するには、コマンドプロンプトで「java–version」を押すと、システムにインストールされているJavaバージョンが出力として表示されます。
IDEのインストール
インターネット上には多数のIDEがあります。好きなように使用できます。このチュートリアルでは、NetBeans8.2を使用しましょう。次の表に、さまざまなIDEのダウンロードリンクを示します。
IDE名 | インストールリンク |
---|---|
NetBeans | https://netbeans.org/downloads/ |
Eclipse | www.eclipse.org/downloads/ |
Intellij | www.jetbrains.com/idea/download/#section=windows |
最新のソフトウェアバージョンを使用して、そこから最大限の機能を引き出すことを常にお勧めします。このチュートリアルでは、NetBeans IDE8.2とJDK8を使用します。
サーバー要件
アプリケーションサーバーとして、Tomcatを使用します。この章では、システムでTomcatサーバーを構成します。最新バージョンのNetBeansをインストールする場合は、NetBeansIDEとともにApacheTomcatを直接インストールできます。そうでない場合は、TOMCATの公式WebサイトからTomcatの最新バージョンをダウンロードしてください。抽出したTomcatファイルをCドライブまたはプログラムファイルに保存します。これらのファイルは次のフェーズで使用されます。
クライアントの要件
RichFacesはUIコンポーネントです。したがって、すべてのUIコンポーネントと同様に、インターネットブラウザはアプリケーションのクライアントとして機能します。IE、Safari、Chromeなどの最新のインターネットブラウザを使用できます。
開発要件
必要なjarのダウンロード:JBOSSの公式Webサイトにアクセスして、JBossjarファイルの最新の安定したリリースをダウンロードしてください。ファイルを抽出します。RichFacesアプリケーションを開発するには、次のjarファイルが必要です。
- richfaces-a4j-4.5.17.Final.jar
- richfaces-core-4.5.17.Final.jar
- richfaces-rich-4.5.17.Final.jar
- cssparser-0.9.18.jar
- guava-19.0.jar
- sac-1.3.jar
プロジェクトの作成
このセクションでは、後でRichFacesの詳細を学ぶために使用するデモアプリケーションを作成しましょう。先に進む前に、前述の必要なすべてのソフトウェアとjarファイルをダウンロードしてインストールすることを強くお勧めします。
Step 1− NetBeansIDEを開きます。[ファイル]→[新しいプロジェクト]に移動します。次のスクリーンショットにリダイレクトされます。
Step 2 −「カテゴリ」タブと「プロジェクト」タブでそれぞれ「JavaWeb」と「Webアプリケーション」を選択し、「次へ」をクリックします。
Step 3−次のタブで、プロジェクト名を入力する必要があります。ここでは、「RichFaceTutorial」という名前を付けましょう。次に、「次へ」をクリックします。次のスクリーンショットにリダイレクトされます。サーバーの詳細を設定する場所。
Step 4−ドロップダウンから「ApacheTomcat」を選択し、「追加」をクリックします。「追加」を押すと、サーバーを構成する必要がある別の画面にリダイレクトされます。サーバーを構成するには、前のセクションでダウンロードしたサーバーファイルが必要です。
Step 5−上のスクリーンショットに示すように、リストから「Apache TomcatまたはTomEE」を選択し、「次へ」をクリックします。次の画面にリダイレクトされます。
Step 6−サーバーの場所で、ダウンロードしたTomcatファイルの場所を指定する必要があります。「参照」をクリックして必要なフォルダパスに移動し、「完了」をクリックします。サーバーが正常に追加されると、最初の画面にリダイレクトされます。「次へ」をクリックすると、次のスクリーンショットに示すように、アプリケーションに追加するさまざまなフレームワークを選択する機会が得られます。
Step 7 −「JavaServerFaces」を選択し、「JavaServer Faces Configuration」で「RichFaces」を選択して、「Finish」を押す必要があります。
オプションとして「RichFaces」を取得しない場合は、ビルドパスから必要なjarファイルを追加できます。この手順が完了すると、アプリケーションをアプリケーションサーバーにデプロイする準備が整います。上記のすべての手順を完了した後のアプリケーションのプロジェクトディレクトリ構造は次のとおりです。
Step 8−先に進み、「index.xhtml」ファイルを左クリックしてファイルを実行します。ブラウザに次の出力が表示されます。
実際のアプリケーションでは、すべてのページが相互リンクされるため、必要なwarファイルを生成してアプリケーションサーバーにデプロイする必要がある場合があります。
ただし、このチュートリアルでは、さまざまなタグのさまざまな機能を表示する必要があるため、アプリケーションページを賢く実行します。
Red Hatの公式ドキュメントによると、リッチなユーザーエクスペリエンスを提供するために内部で機能するコンポーネントは全部で5つあります。以下は5つのコンポーネントです。
AJAX Filter− AJAXフィルターは、クライアントブラウザーからのさまざまなタイプのリクエストを区別するために使用されます。このコンポーネントをアプリケーションに含めるには、RichFacesFilterをアプリケーションのweb.xmlファイルに登録する必要があります。AJAX Filterは、JSFアプリケーションのさまざまなフェーズで異なる動作をします。
AJAX Action Components −アクションコンポーネントは、ブラウザからAJAXエンジンにクライアントリクエストを送信し、そこからリクエストを処理して、必要なビューをレスポンスとしてレンダリングします。
AJAX Containers− AJAXコンテナは、概念的にはSpringコンテナに似ています。基本的に、AJAXリクエストを処理するためにクライアントブラウザの特定の領域を認識しています。
Skinnability−スキンとテーマを合わせてスキナビリティと呼びます。このモジュールは独立して機能し、全体のルックアンドフィールを広範囲にサポートします。
RichFaces JavaScript Engine− JavaScriptエンジンは、応答を準備するためにAJAXエンジンに更新を送信するクライアント側で実行されます。このエンジンは自動的に動作するため、それを制御するために余分なコード行を記述する必要はありません。
以下は、MVCパラダイムでのRichFacesアプリケーションのアーキテクチャ図です。
上の画像では、ユーザーのアクティビティは「JSイベント」として処理されます。その後、「JSイベント」は「XMLフィルター」に送信されます。これはAJAXフィルターのコンポーネントに他なりません。「XMLフィルター」は、ユーザー要求の生成と処理を担当します。他のすべてのコンポーネントは、さまざまなjarファイルの内部にあります。これらの機能を使用するには、適切なタグライブラリを使用する必要があります。
この章では、RichFacesのいくつかの基本的な概念を確認し、RichFacesがAJAXリクエストの処理やその他の多くの機能をどのように処理するかを学習します。
AJAXリクエストの処理
前述のように、RichFacesは、AJAXコードを実装しなくてもWebアプリケーションでAJAX機能を有効にする豊富なUIコンポーネントを提供します。これらのAJAX機能はすべて、a4:j タグライブラリ。 <a4j:commandLink> , <a4j:commandButton>, <a4j:support>、および <a4j:poll>開発者がAJAX機能をWebアプリケーションに組み込むのに役立つ4つのタグです。タグライブラリについては、次の章で詳しく説明します。
部分的なツリー処理
従来のAJAXアプリケーションでは、すべての入力フィールドがツリーの異なるノードとして処理されますが、RichFacesでは、ツリーノードを部分的に送信し、必要なフィールドを検証するオプションがあります。
これについてもっと理解するために例を考えてみましょう。HTMLには、「名前」、「従業員ID」、「従業員の給与」、「従業員の住所」、「従業員部門」の合計5つの要素があるとします。ここで、従業員IDのみを検証または処理する必要があります。これは、RichFacesを使用して可能ですが、AJAXを使用しては不可能です。フォーム全体をサーバーに送信する必要があります。RichFacesは、特定のコンポーネントを識別して同じものを処理できる実行属性を提供します。以下は、使用可能な実行属性のさまざまなレベルです。
@all −この属性は、すべてのデータを処理します。
@none −これは、データを処理したくない場合に使用できます。
@this −これは要求しているコンポーネントのみを処理します。
@form −これにより、要求しているコンポーネントを含むフォーム全体が処理されます。
@region −これにより、Webページの特定の領域が処理されます。
部分ビューの更新
入力フィールドと同様に、RichFacesはさまざまなビューを更新するための同様のオプションを提供します。開発者は、選択に応じてビューをカスタマイズできます。execute属性と同様に、execute属性と同様に機能するrender属性があります。これらの属性はすべて、WebページのID識別子に基づいて機能します。
以下は、使用可能なレンダリング属性のさまざまなレベルです。
@all −これにより、コンポーネント全体が更新されます。
@none −これはコンポーネントを更新しません。
@this −これにより、要求しているコンポーネントのみが更新されます。
@from −これにより、要求データを含むフォームが更新されます。
@region −これにより、Webページの特定の領域が更新されます。
その他のa4jタグ
これまで、RichFacesアプリケーションの概念的なプロパティについて説明してきました。このセクションでは、実践的な例を使用して、それらについて詳しく学習します。
<a4j:AJAX>
これは、RichFacesが提供するコアコンポーネントの1つです。これは、JSF2.0 f:AJAXタグの拡張部分に他なりません。このタグは、WebページでJSイベントが発生するたびにAJAXリクエストをトリガーします。次の例では、このタグについて詳しく説明します。Webページフォルダの下に「xhtml」ページを作成し、「a4jAJAXExample.xhtml」という名前を付けます。次に、次のコードを貼り付けます。
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://xmlns.jcp.org/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>a4j:AJAX Tag Example</title>
</h:head>
<h:body>
<h:form id = "form">
<h:inputText value = "#{managedBean.message}">
<a4j:AJAX render = "ShowMessage" />
</h:inputText>
<h:outputText value = "#{managedBean.message}" id = "ShowMessage"
style = "animation-duration"/>
</h:form>
</h:body>
</html>
また、Webページからの入力を保持するためにマネージドBeanを作成する必要があります。先に進み、ソースパッケージディレクトリの下にJavaクラスを作成します。以下はmanagedbean.java クラスコード。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class managedBean {
String message;
public String getMessage() {
return message;
}
public void setMessage(String message) {
this.message = message;
}
}
両方のファイルを保存して実行すると、ブラウザに次の出力が表示されます。
<a4j:param>
a4j:paramは、f:paramタグの拡張です。プロパティまたはインスタンス変数に値を割り当てるために使用されます。このタグは、インスタンス変数に値を永続的に割り当てることができます。以下は「a4jparamExample.html」コードです。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://xmlns.jcp.org/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>Param tag example</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form id = "form">
<h:panelGrid columns = "2">
<a4j:commandButton value = "TutorialsPoint" render = "rep">
<a4j:param value = "Tutorials point" assignTo = "#{managedBean.message}" />
</a4j:commandButton>
<a4j:commandButton value = "RichFace Tutorials" render = "rep">
<a4j:param value = "RichFace Tutorials" assignTo = "#{managedBean.message}" />
</a4j:commandButton>
</h:panelGrid>
<br />
<h:outputText id = "rep" value = "Selected Name:#{managedBean.message}" />
</h:form>
</h:body>
</html>
以下は、対応するマネージドBeanクラスコードです。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class managedBean {
String message;
public String getMessage() {
return message;
}
public void setMessage(String message) {
System.out.println("This method is getting called with"+message);
// we have added this line in order to check how the AJAX call
// happens to the class methods without any direct communication
this.message = message;
}
}
先に進み、ファイルを実行します。以下はブラウザでの出力です。
これで、サーバーコンソールに次の出力が表示されます。これは、実行時にインスタンス変数を設定するために、xhtmlファイルがマネージドBeanと通信していることを示しています。
<a4j:commandButton>
前の例では、コマンドボタンタグをすでに使用しています。これは、xhtmlページ内にボタンを作成するために使用されます。このボタンは、AJAXエンジンを生成して通信し、特定のリクエストを処理します。入力を受け取り、同じ処理を行い、Webブラウザで出力をレンダリングします。
前の例では、「TutorialsPoint」と「RichFaceTutorials」の2つのボタンを作成しました。コマンドボタンタグは、マネージドBeanと内部的に通信し、必要なインスタンス変数を設定します。また、値のレンダリングも担当します。
<a4j:commandLink>
コマンドリンクは、JSF 2.0の<h:commandlink>コンポーネントのように機能します。コマンドリンクがJSクリックイベントで機能するときはいつでも、コマンドボタンは送信ベースのAJAXリクエストを生成します。これが、コマンドボタンとコマンドリンクの唯一の違いです。次の例は、タグライブラリをよりよく理解するのに役立ちます。「a4jCommandLink.xhtml」ファイルを作成し、次のコードを貼り付けます。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://xmlns.jcp.org/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>Example of command Link</title>
</h:head>
<h:body>
<h:form id = "form">
<h:panelGrid columns = "3">
<h:outputText value = "Name:" />
<h:inputText value = "#{managedBean.message}" />
<a4j:commandLink value = "Click Me" render = "out" execute = "@form" />
</h:panelGrid>
</h:form>
<br />
<a4j:outputPanel id = "out">
<h:outputText value = "Welcome to #{managedBean.message} !" />
</a4j:outputPanel>
</h:body>
</html>
マネージドBeanクラスでは何も変更する必要はありません。このファイルを実行すると、ブラウザに次のように出力されます。
<a4j:outputPanel>
出力パネルは、HTMLページのスパンとして機能します。これは、Webページのさまざまなコンポーネントを個別に指定するのではなく、グループ化するために使用されます。前の例では、入力テキストボックスに表示されたメッセージを表示するために出力パネルを使用しました。以下は、出力パネルの構文です。
<a4j:outputPanel id = "out">
<h:outputText value = "Welcome to #{managedBean.message} !" />
</a4j:outputPanel>
<a4j:region>
これはRichFacesの重要な機能であり、からWebページの一部を処理できます。このタグを使用すると、RichFacesで部分的なツリー処理が行われます。これは主にレンダリングプロセスを増やすために使用されます。次の例は、これを詳細に理解するのに役立ちます。次のコードを使用して「a4jregionExample.xhtml」ファイルを作成してください。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j" >
<h:head>
<title>Region Example</title>
</h:head>
<h:body>
<h:form>
<h:inputText value = "#{managedBean.message}"/>
<h:inputText value = "#{managedBean.job}"/>
<a4j:commandLink id = "one" value = "one"/>
<a4j:region>
<h:inputText value = "#{managedBean.message}"/>
<a4j:commandLink id = "two" value = "two"/>
</a4j:region>
</h:form>
</h:body>
</html>
このxhtmlページとともに、それに応じてmanagedBeanを更新してください。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class managedBean {
String message;
String job;
public String getMessage() {
return message;
}
public void setMessage(String message) {
System.out.println("setMessage method is getting called with--"+message);
this.message = message;
}
public String getJob() {
return job;
}
public void setJob(String job) {
System.out.println("setJob method is getting called with--"+job);
this.job = job;
}
}
上記のコードは、ブラウザに次の出力を生成します。
コマンドリンク「1」をクリックするとフォーム全体が処理されますが、コマンドリンク「2」をクリックすると、メッセージインスタンスのみが領域タグで囲まれているため処理されます。同様に、コマンドリンク「one」を別のリージョンタグで囲むと、最初の2つの入力パラメーターのみが処理されます。以下は、コマンドリンク「two」がクリックされたときのサーバーコンソールのスクリーンショットです。
コマンドリンク「one」をクリックするたびに、以下が出力されます。
<a4j:repeat>
リピートタグは、JSFの<ui:repeat>タグとまったく同じように機能します。Webページのリストを反復処理するのに役立ちます。次の「a4jRepeat.xhtml」ファイルの例では、マネージドBeanクラスのリストを反復処理しています。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head></h:head>
<h:body>
<h:form id = "form">
<h:panelGrid columns = "1" style = "width: 640px">
<a4j:outputPanel id = "panel" layout = "block">
<a4j:repeat value = "#{managedBean.subjectList}" var = "sub">
<li>
<h:outputText value = "#{sub}"/>
</li>
</a4j:repeat>
</a4j:outputPanel>
</h:panelGrid>
</h:form>
</h:body>
</html>
この特定のファイルをブラウザで実行すると、次の出力が得られます。
<a4j:status>
名前が示すように、このタグは、フロントエンドでAJAXリクエストのステータスを表示する場合に役立ちます。選択に応じて、通常のテキストメッセージ、gif、または画像ベースのステータスを含めることができます。次のような小さなアプリケーションの場合、フロントエンドのステータスを垣間見ることができますが、複雑なAJAXリクエストを実行しているときはいつでも、このステータスは非常に目立ちます。以下に示すように「a4jregionExample.xhtml」を変更してください。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>Region Example</title>
</h:head>
<h:body>
<h:form>
<a4j:status startText = "Working..." />
<h:inputText value = "#{managedBean.message}"/>
<h:inputText value = "#{managedBean.job}"/>
<a4j:commandLink id = "one" value = "one"/>
<a4j:region>
<h:inputText value = "#{managedBean.message}"/>
<a4j:commandLink id = "two" value = "two"/>
</a4j:region>
<a4j:status startText = "Done" />
</h:form>
</h:body>
</html>
このアプリケーションを実行しているときはいつでも、「作業中...」と「完了」の2つのステータスを垣間見ることができます。これらのステータスは、リクエストが完了するたびに自動的に消えます。
<a4j:include> / <a4j:keepAlive>
インクルードとキープアライブ。どちらのタグもRichFaces3.0で導入されましたが、RichFaces 4では、<ui:include>や<ui:insert>などのFaceletsで使用される他のさまざまなタグを使用してこれらの機能を簡単に実現できるため、これらのタグは減価償却されました。名前が示すように、includeは、あるページを別のページに含めるために導入され、keepAliveは、JSFページに関連付けられたマネージドBeanのスコープを制御するために導入されました。ビジネス目標を達成するには、ソフトウェアAPIの更新バージョンを使用し、<UI>コンポーネントと「注釈」実装を使用することをお勧めします。
<a4j:log>
名前が示すように、このa4jコンポーネントは、Webブラウザーにロギング情報を生成するのに役立ちます。次の例では、このタグについて詳しく説明しています。「a4jregionExample.xhtml」ファイルを次のように編集します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>Region Example</title>
</h:head>
<h:body>
<h:form>
<a4j:status startText = "Working..." />
<h:inputText value = "#{managedBean.message}"/>
<h:inputText value = "#{managedBean.job}"/>
<a4j:commandLink id = "one" value = "one"/>
<a4j:region>
<h:inputText value = "#{managedBean.message}"/>
<a4j:commandLink id = "two" value = "two"/>
</a4j:region>
<a4j:log></a4j:log>
<a4j:status startText = "Done" />
</h:form>
</h:body>
</html>
上記のコードをブラウザで実行すると、次のように出力されます。a4j:logは、必要に応じてすべてのレベルの必要なログを生成します。
<a4j:jsFunction>
これはRichFacesの最も高度な機能であり、JavaScriptコードなしで自動JS関数を作成できます。CDKは、JSイベントに基づいて自動JavaScriptコードを生成します。
次の例では、指定された値にカーソルを合わせるたびに呼び出されるJavaScript関数を作成しています。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j">
<h:head>
<title>Example of JS Function</title>
</h:head>
<h:body>
<table width = "500" border = "1">
<tbody>
<tr>
<td>
<span onmouseover = "showMySkill('core java,J2EE')"
onmouseout = "showMySkill('')">BackEnd developer</span>
</td>
<td>
<span onmouseover = "showMySkill('DB,RDBMS,unix')"
onmouseout = "showMySkill('')">Database Admin</span>
</td>
<td>
<span onmouseover = "showMySkill(
'JS frameworks,html,java scripts')"
onmouseout = "showMySkill('')">Front End Developer</span>
</td>
</tr>
<tr>
<td colspan = "3">You need to know:
<b><h:outputText id = "showSkillset" value = "#{managedBean.message}"/></b>
</td>
</tr>
</tbody>
</table>
<h:form id = "form">
<a4j:jsFunction name = "showMySkill" render = "showSkillset">
<a4j:param name = "name" assignTo = "#{managedBean.message}" />
</a4j:jsFunction>
</h:form>
</h:body>
</html>
上記のコードは、ブラウザで次の出力を生成します。JSイベントに応じて、CDKは「showMySkill()」という名前のメソッドをオーバーライドし、必要な値がブラウザーに出力されます。
<a4j:AJAXListener>
このタグは、結果をブラウザにレンダリングする直前に特定のリスナーを実行する場合に使用されます。このタグはRichFaces4では使用できません。これは、同じ機能がで使用できるためです。
<rich:panel>
<f:facet name = "header">Using a4j:actionListener</f:facet>
<a4j:commandButton value="Submit" reRender = "#{AJAXBean.areas}">
<a4j:AJAXListener binding = "#{AJAXBean.renderAreasListener}"/>
</a4j:commandButton>
</rich:panel>
上記の例では、「送信」ボタンをクリックすると、JSイベントが作成され、Beanクラス内に実装された「areas」メソッドが呼び出され、対応する結果が結果としてレンダリングされます。
RichFacesには、Rich Skinと呼ばれる、Webサイトのルックアンドフィールを一元的に制御するための新機能が付属しています。スキンは古いCSSファイルの高レベルの実装であり、バックエンド開発者がWebサイトのルックアンドフィールを制御するのにより便利です。いくつかの組み込みスキンが利用可能であり、選択に応じてカスタマイズできます。
ビルトインスキン
RichFacesコンポーネントのjarファイルには多数の組み込みスキンがあります。以下は、利用可能ないくつかの組み込みのリッチスキンです。
- Default
- Plain
- emeraldTown
- blueSky
- wine
- japanCherry
- ruby
- classic
- deepMarine
- NULL
次の例では、「クラシック」スキンを実装します。上記のスキンのいずれかを実装するのは非常に簡単です。先に進む前に、以下のコード行を使用して「web.xml」ファイルにスキンを追加してください。上記のリストから任意のスキンを追加できます。<param-value>タグを適切なスキン名で変更する必要があります。
<context-param>
<param-name>org.richfaces.skin</param-name>
<param-value>classic</param-value>
</context-param>
これを追加した後、「SkinExample.xhtml」ファイルを作成し、次のコード行を追加してください。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<f:view>
<h:head>
<title>Rich Faces Built in Skin</title>
</h:head>
<h:body>
<h:form>
<rich:panel style = "width:60%">
<rich:tabPanel switchType = "AJAX">
<rich:tab header = "Name">
Tutorials Point
</rich:tab>
<rich:tab header = "Features">
Best Place to learn
</rich:tab>
</rich:tabPanel>
</rich:panel>
</h:form>
</h:body>
</f:view>
</ui:composition>
このページを実行すると、ブラウザの出力は次のようになります。各タブは動的に伝播して、異なる出力を生成します。次のタブを押すと、別の出力が表示されます。
上記の例では、<rich:panel>は、<rich:tab>を使用してさまざまなタブを作成するパネルを作成します。<rich:tabPanel switchType = "AJAX">は、使用されているタブのAJAX遷移を提供します。
スキンの作成/変更
スキンはCSSデザインの拡張バージョンに他ならず、実行時にWebページに適用されます。前のセクションでは、スキンの基本的な組み込み機能について学びました。このセクションでは、独自のスキンを作成するか、既存のスキンを変更します。RichFacesのスキンは、次の3つのレベルでカスタマイズできます。
Skin property file−すべてのスキンは、「rechfaces-a4j-4.5.17.Final」jarファイルに記載されているさまざまなプロパティファイルを介して生成されます。同じプロパティファイルを作成し、それをソースフォルダーの下に保持して、そのプロパティを編集するだけです。Webサイトの新しいスキンプロパティを反映するために、それに応じて「web.xml」を変更する必要があります。
Component style sheet −選択した新しいCSSファイルを実装し、アプリケーションで使用します。
Overwrite style class − xhtmlファイルでスタイルプロパティを直接参照することにより、スタイルを上書きできます。
例を考えてみましょう。以前の「クラシック」スキンをカスタマイズします。「source」パッケージ内にプロパティファイルを作成し、「custom.skin.properties」という名前を付けます。以下は、上記のjarファイルで使用可能な他のプロパティファイルからコピーされたこのプロパティファイルのエントリです。
#Colors
headerBackgroundColor = #black
headerGradientColor = #DF5858
headerTextColor = #FFFFFF
headerWeightFont = bold
generalBackgroundColor = #f1f1f1
generalTextColor = #000000
generalSizeFont = 10px
generalFamilyFont = Arial, Verdana, sans-serif
controlTextColor = #000000
controlBackgroundColor = #ffffff
additionalBackgroundColor = #F9E4E4
shadowBackgroundColor = #000000
shadowOpacity = 1
panelBorderColor = #C0C0C0
subBorderColor = #ffffff
tabBackgroundColor = #EDAEAE
tabDisabledTextColor = #C47979
trimColor = #F7C4C4
tipBackgroundColor = #FAE6B0
tipBorderColor = #E5973E
selectControlColor = #FF9409
generalLinkColor = #CF0000
hoverLinkColor = #FF0000
visitedLinkColor = #CF0000
# Fonts
headerSizeFont = 11px
headerFamilyFont = Arial, Verdana, sans-serif
tabSizeFont = 11
tabFamilyFont = Arial, Verdana, sans-serif
buttonSizeFont = 11
CHAPTER 11 ■ SKINS 223
buttonFamilyFont = Arial, Verdana, sans-serif
tableBackgroundColor = #FFFFFF
tableFooterBackgroundColor = #cccccc
tableSubfooterBackgroundColor = #f1f1f1
tableBorderColor = #C0C0C0
tableBorderWidth = 1px
#Calendar colors
calendarWeekBackgroundColor = #f5f5f5
calendarHolidaysBackgroundColor = #FFF1F1
calendarHolidaysTextColor = #980808
calendarCurrentBackgroundColor = #808080
calendarCurrentTextColor = #ffffff
calendarSpecBackgroundColor = #f1f1f1
calendarSpecTextColor = #000000
warningColor = #FFE6E6
warningBackgroundColor = #FF0000
editorBackgroundColor = #F1F1F1
editBackgroundColor = #FEFFDA
#Gradients
Gradient Type = plain
スキルレベルに応じて、このプロパティファイルの任意の属性を変更できます。新しいStyleクラスを追加したり、既存のクラスを編集したりできます。新しいプロパティファイルの作成が完了したら、「web.xml」ファイルに同じものを追加します。以下は、スキンを指す「web.xml」のエントリです。
<context-param>
<param-name>org.richfaces.skin</param-name>
<param-value>custom</param-value>
</context-param>
Note −新しいプロパティファイルがソースディレクトリ内に存在することを確認してください。存在しない場合、「NoClassFoundException」というランタイムエラーがスローされます。
先に進み、「SkinExample.xhtml」という名前の前のファイルを実行します。以下はブラウザでの出力です。ここでは、新しいプロパティファイルがruby.propertiesファイルからコピーされたため、Webサイトのルックアンドフィール全体が「Ruby」に変更されたことがわかります。
実行時のスキンの変更
この例では、実行時にスキンを変更します。次のようなスキンクラスを作成します。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class skinBean {
private String skin;
public skinBean() {
this.skin="plane";
}
public String getSkin() {
return skin;
}
public void setSkin(String skin) {
this.skin = skin;
}
}
次に、「web.xml」ファイルを次のように変更して、実行時にスキン名を入力します。
<context-param>
<param-name>org.richfaces.skin</param-name>
<param-value>#{skinBean.skin}</param-value>
</context-param>
その後、JSFアプリケーションの構成ファイルを変更する必要があります。ファイルはweb-INFフォルダーの下にあります。次のBeanプロパティを追加します。
<managed-bean>
<managed-bean-name>skinBean</managed-bean-name>
<managed-bean-class>SkinBean</managed-bean-class>>
<managed-bean-scope>session</managed-bean-scope>
<managed-property>
<property-name>skin</property-name>
<value>plain</value>
</managed-property>
</managed-bean>
以下はxhtmlファイルコードです。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>TODO supply a title</title>
</h:head>
<h:body>
<h:form>
<div style = "display: block; float: left">
<h:selectOneRadio value = "#{skinBean.skin}" border = "0"
layout = "pageDirection" title = "Changing skin" style = "font-size: 8;
font-family: comic" onchange = "submit()">
<f:selectItem itemLabel = "plain" itemValue = "plain" />
<f:selectItem itemLabel = "emeraldTown" itemValue = "emeraldTown" />
<f:selectItem itemLabel = "blueSky" itemValue = "blueSky" />
<f:selectItem itemLabel = "wine" itemValue = "wine" />
<f:selectItem itemLabel = "japanCherry" itemValue = "japanCherry" />
<f:selectItem itemLabel = "ruby" itemValue = "ruby" />
<f:selectItem itemLabel = "deepMarine" itemValue = "deepMarine" />
</h:selectOneRadio>
</div>
<div style = "display: block; float: left">
<rich:panel >
<rich:panelMenu style = "font-family: monospace; font-size: 12;">
Changing skin in runtime
</rich:panelMenu>
<rich:panelMenu style = "font-family: monospace; font-size: 12;">
This is a result of the modification "blueSky" skin
</rich:panelMenu>
</rich:panel>
</div>
</h:form>
</h:body>
</html>
上記のコードは、ブラウザで次の出力を生成します。
上記の例では、最初は「プレーン」を選択しているため、プレーンを指しています。ラジオボタンを介して伝播すると、それに応じて色が変わります。
これまで、RichFacesのさまざまなAJAXコンポーネントと、「スキン」と呼ばれる新機能について多くのことを学びました。この章では、RichFacesが最新のWebアプリケーションを開発するために提供するさまざまな「Rich」コンポーネントについて学習します。以下は、「RichFaces」によって提供されるさまざまな入力コンポーネントです。
<rich:inplaceInput>
豊富なinplaceInputは、通常の入力テキストボックスの代わりに編集可能なテキストボックスを作成する機会を提供します。次の例では、このコンポーネントを使用して編集可能なテキストボックスを作成します。xhtmlファイルを作成し、「richinplaceInput.xhtml」という名前を付けます。そのファイルに次のコードを記述します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>TODO supply a title</title>
</h:head>
<h:body>
<f:view></f:view>
<h:form>
<rich:inplaceInput value = "#{managedBean.message}"
defaultLabel = "Enter Your Name"/>
</h:form>
</h:body>
</html>
このファイルを保存して実行します。以下はブラウザでの出力です。
先に進み、そのテキストボックスに任意の項目を入力して、Enterキーを押します。このタグは、インライン編集オプションも提供します。編集後、以下が出力されます。
<リッチ:inplaceSelect>
これはRichFacesが提供するもう1つの入力マークアップであり、ユーザーはドロップダウンリストから入力値を選択できます。これもインラインで編集可能です。内部Beanクラスからドロップダウンを設定する必要があります。「xhtml」ファイルを作成し、「richinplaceSelectExample.xhtml」という名前を付けてください。そのファイルに次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>TODO supply a title</title>
</h:head>
<h:body>
<h:form>
<rich:inplaceSelect value = "#{subject.subjectName}" defaultLabel = "Click to Select Country">
<f:selectItems value = "#{subject.SubJectList()}"></f:selectItems>
</rich:inplaceSelect>
</h:form>
</h:body>
</html>
上記の例では、バックエンドからドロップダウンオプションを設定します。これが「subject.java」という名前のBeanクラスです。
import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ManagedProperty;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class Subject {
String SubjectName;
public Subject() {
}
public Subject(String SubjectName) {
this.SubjectName = SubjectName;
}
public List<String> SubJectList() {
//this list to be rendered
ArrayList<String> list = new ArrayList<>();
list.add("JAVA");
list.add("DOTNET");
list.add("COBOL");
list.add("AJAX");
list.add("JAVA SCRIPT");
return list;
}
public String getSubjectName() {
return SubjectName;
}
public void setSubjectName(String SubjectName) {
this.SubjectName = SubjectName;
}
}
リストを通過するすべてのサブジェクト名は、ドロップダウンメニュー内に表示されます。このアプリケーションを実行した後の出力は次のとおりです。
<rich:SuggestionBox>
<rich:SuggestionBox>は、入力テキストボックスに入力された内容に応じて、ユーザーに提案を提供するために使用されます。このタグは内部でJSイベントを作成し、必要なistenerクラスを呼び出して、バックエンドからの提案を提供します。残念ながら、このsuggestionBoxとComboBoxは両方ともRichFaces 4では「<rich:autocomplete>」と呼ばれる個別のタグに結合されていますが、RichFaces 3を使用している場合は、以下に示すようにこのタグを使用できます。
<h:inputText id = "city" value = "#{capitalsBean.capital}" />
<rich:suggestionbox for = "city" var = "result"
suggestionAction = "#{capitalsBean.autocomplete}">
<h:column>
<h:outputText value = "#{result.name}" />
</h:column>
</rich:suggestionbox>
「capitalsBean」はさまざまなパラメータを持つJavaクラスであり、「autocomplete」という名前のリスナークラスは、実行時に「capital」インスタンス変数の値を設定し、必要な出力を提供します。設計者はこのタグをサポートしなくなったため、このタグを使用する代わりに、RichFaces4の「オートコンプリート」を使用することを強くお勧めします。
<rich:comboBox>
<rich:comboBox>は<rich:suggestionBox>とまったく同じように機能しますが、このタグは、リスナークラスを呼び出す代わりに、相互に対話して目的の出力を提供するいくつかの提案をクライアントブラウザーに事前にレンダリングします。<rich:sugegstionBox>と同様に、この機能も新しいバージョンで廃止され、次のコードで説明する「<rich:autocomplete>」という別のタグが付けられます。
別のファイルを作成し、「richAutoComplete.xhtml」という名前を付けます。そのファイルに次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head></h:head>
<h:body>
<h:form id = "form">
<h:form id = "form">
<rich:autocomplete mode = "cachedAJAX" minChars = "2"
autocompleteMethod = "#{autoComplete.SubJectList()}" />
</h:form>
</h:form>
</h:body>
</html>
上記の例では、RichFacesのオートコンプリート機能を使用してサブジェクトリストにデータを入力しています。別のJavaクラスを作成し、「autoComplete.java」という名前を付けます。
import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class autoComplete {
public autoComplete(){}
private List<String> autoCompleteList=new ArrayList<>();
public List<String> SubJectList() {
//ArrayList<String> list = new ArrayList<>();
autoCompleteList.add("JAVA");
autoCompleteList.add("DOTNET");
autoCompleteList.add("COBOL");
autoCompleteList.add("AJAX");
autoCompleteList.add("JAVA SCRIPT");
return autoCompleteList;
}
public List<String> getAutoCompleteList() {
return autoCompleteList;
}
public void setAutoCompleteList(List<String> autoCompleteList) {
this.autoCompleteList = autoCompleteList;
}
}
上記のファイルはBeanクラスとして機能し、SubjectList()はメソッドであり、実際にブラウザーへの応答をレンダリングしています。<SuggestionBox>、<ComboBox>タグでは、リスナークラスを実装する必要がありますが、<autocomplete>タグの場合、このリスナークラスの作成は自動化されているため、開発者にとっては簡単です。上記のコードは、ブラウザに次の出力を生成します。
<rich:inputNumberSlider>
これは、開発者が数値間隔に応じて数値スライダーバーを作成するのに役立つ非常に単純なタグです。「inputNumberSlider.xhtml」ファイルを作成し、その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head></h:head>
<h:body>
<h:form>
<h:outputText value = "Slide Bar example"></h:outputText>
<rich:inputNumberSlider
minValue = "1"
maxValue = "10"
showArrows = "false"
showTooltip = "false"
step = "1">
</rich:inputNumberSlider>
</h:form>
</h:body>
</html>
上記の例では、属性はかなり説明的です。上記のコードは、ブラウザに次の出力を生成します。
<リッチ:カレンダー>
名前が示すように、このタグはブラウザでカレンダーを作成するのに役立ちます。別のファイルを作成し、「richCalendar.xhtml」という名前を付けます。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head></h:head>
<h:body>
<h:form>
<h1>Calendar</h1>
<rich:calendar value = "#{calendarBean.selectedDate}"
locale = "#{calendarBean.locale}"
popup = "#{calendarBean.popup}"
datePattern = "#{calendar.pattern}"
style = "width:200px">
</rich:calendar>
</h:form>
</h:body>
</html>
Date、Locale、Date Patternなどのすべてのカレンダー値を保持するために、「calendarBean.java」という別のクラスを作成する必要があります。以下は「calendarBean.java」のコードです。
import java.text.DateFormat;
import java.util.Date;
import java.util.Locale;
import javax.faces.event.ValueChangeEvent;
public class CalendarBean {
private static final String[] WEEK_DAY_LABELS = new String[] {
"Sun *", "Mon +", "Tue +", "Wed +", "Thu +", "Fri +", "Sat *" };
private Locale locale;
private boolean popup;
private boolean readonly;
private boolean showInput;
private boolean enableManualInput;
private String pattern;
private Date currentDate;
private Date selectedDate;
private String jointPoint;
private String direction;
private String boundary;
private boolean useCustomDayLabels;
public Locale getLocale() {
return locale;
}
public void setLocale(Locale locale) {
this.locale = locale;
}
public boolean isPopup() {
return popup;
}
public void setPopup(boolean popup) {
this.popup = popup;
}
public String getPattern() {
return pattern;
}
public void setPattern(String pattern) {
this.pattern = pattern;
}
public CalendarBean() {
locale = Locale.US;
popup = true;
pattern = "MMM d, yyyy";
jointPoint = "bottomleft";
direction = "bottomright";
readonly = true;
enableManualInput = false;
showInput = true;
boundary = "inactive";
}
public boolean isShowInput() {
return showInput;
}
public void setShowInput(boolean showInput) {
this.showInput = showInput;
}
public boolean isEnableManualInput() {
return enableManualInput;
}
public void setEnableManualInput(boolean enableManualInput) {
this.enableManualInput = enableManualInput;
}
public boolean isReadonly() {
return readonly;
}
public void setReadonly(boolean readonly) {
this.readonly = readonly;
}
public void selectLocale(ValueChangeEvent event) {
String tLocale = (String) event.getNewValue();
if (tLocale != null) {
String lang = tLocale.substring(0, 2);
String country = tLocale.substring(3);
locale = new Locale(lang, country, "");
}
}
public boolean isUseCustomDayLabels() {
return useCustomDayLabels;
}
public void setUseCustomDayLabels(boolean useCustomDayLabels) {
this.useCustomDayLabels = useCustomDayLabels;
}
public Object getWeekDayLabelsShort() {
if (isUseCustomDayLabels()) {
return WEEK_DAY_LABELS;
} else {
return null;
}
}
public String getCurrentDateAsText() {
Date currentDate = getCurrentDate();
if (currentDate ! = null) {
return DateFormat.getDateInstance(DateFormat.FULL).format(currentDate);
}
return null;
}
public Date getCurrentDate() {
return currentDate;
}
public void setCurrentDate(Date currentDate) {
this.currentDate = currentDate;
}
public Date getSelectedDate() {
return selectedDate;
}
public void setSelectedDate(Date selectedDate) {
this.selectedDate = selectedDate;
}
public String getJointPoint() {
return jointPoint;
}
public void setJointPoint(String jointPoint) {
this.jointPoint = jointPoint;
}
public void selectJointPoint(ValueChangeEvent event) {
jointPoint = (String) event.getNewValue();
}
public String getDirection() {
return direction;
}
public void setDirection(String direction) {
this.direction = direction;
}
public void selectDirection(ValueChangeEvent event) {
direction = (String) event.getNewValue();
}
public String getBoundary() {
return boundary;
}
public void setBoundary(String boundary) {
this.boundary = boundary;
}
}
上記のコードは、ブラウザで次の出力を生成します。
<rich:InputNumberSpinner>
このタグは、開発者がBeanのインスタンスにデータを取り込むためのスピナーを作成するのに役立ちます。以下は、Spinnerタグを詳細に理解するのに役立つ例です。別のxhtmlファイルを作成し、「InputNumberSpinner.xhtml」という名前を付けて、その中に次のコードを配置してください。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Number Slider Example</title>
</h:head>
<h:body>
<h:form>
<h:outputText value = "Select a Date"></h:outputText>
<br/>
<br/>
<rich:inputNumberSpinner
minValue = "1"
maxValue = "31"
step = "1">
</rich:inputNumberSpinner>
</h:form>
</h:body>
</html>
上記のコードは、ブラウザに次の出力を生成します。
前の章では、ユーザーがブラウザーを介して入力を提供するのに役立つさまざまな入力フィールドまたはタグについて学習しました。この章では、RichFacesが提供するさまざまな出力コンポーネントについて学習します。
<リッチ:パネル>
以前の例のいくつかでは、すでにパネルタグに出くわしました。<rich:panel>は、Webページ内に長方形の領域を作成します。この領域には、任意の情報が含まれる場合があります。1つのパネル内に、他のパネル、画像、およびその他の豊富なコンポーネントを含めることができます。
次の例では、選択に応じてカスタムパネルを作成し、「header」属性を使用してパネルにヘッダーを提供します。xhtmlファイルを作成し、「richPanelExamlple.xhtml」という名前を付けてください。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Panel Example</title>
</h:head>
<h:body>
<rich:panel header = "RichFace Tutorials " style = "font-size: 500px;
align-items:center; background-color: activecaption">
RichFace Tutorials Presented by TutorialsPoint.com.
</rich:panel>
</h:body>
</html>
上記のコードは、ブラウザに次の出力を生成します。
<rich:simpleTogglePanel>
simpleTogglePanelは、開発者にパネルの内容を動的に変更する機会を提供します。ただし、RichFaces 4では、このタグは抑制されています。JBossは、<rich:togglePanel>、<rich:tab>、<rich:tabPanel>などの高度なタグを導入しました。より多くの機能を利用するには、更新されたバージョンのRichFacesタグを使用することをお勧めします。まだRichFaces3を使用している場合は、次のタグを使用できます。
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<rich:simpleTogglePanel switchType = "client" label = "SimpleToggle">
The simple example of SimpleToggle tag
</rich:simpleTogglePanel>
</ui:composition>
<rich:tabPanel>
このタグは、開発者がパネル内にさまざまなタブを作成するのに役立ちます。このタグはスキンの章で使用し、別のパネル内に2つの別々のタグを作成しました。次のコードは、<rich:tabPanel>の使用方法を説明しています。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<f:view>
<h:head>
<title>Rich Faces Tab Example</title>
</h:head>
<h:body>
<h:form>
<rich:panel style = "width:60%">
<rich:tabPanel switchType = "AJAX">
<rich:tab header = "Name">
Tutorials Point----This is Tab Number 1
</rich:tab>
<rich:tab header = "Features">
Best Place to learn -------This is Tab Number 2
</rich:tab>
</rich:tabPanel>
</rich:panel>
</h:form>
</h:body>
</f:view>
</ui:composition>
この例では、「Name」と「Features」という異なるヘッダーを持つ2つのタブを作成しました。これらの2つのタグは、<rich:panel>内に作成されます。上記のコードは次の出力を生成します。
<rich:panelBar>
simpleToggleBarと同様に、開発者はJSイベントに応じて垂直方向の切り替えを実装できます。このタグはRichFaces4でも抑制されていますが、RichFaces 3.0を使用している場合は、以下のように使用できます。。
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<rich:panelBar height = "400" width = "500">
<rich:panelBarItem label = "Toggle1”>
First vertical toggle
</rich:panelBarItem>
<rich:panelBarItem label = ”Toggle2”>
Second Vertical Toggle
</rich:panelBarItem>
</rich:panelBar >
</ ui:composition >
RichFaces 4では、<rich:PanelMenu>タグを使用して同じ機能が実装されています。
<rich:tab>
私たちはすでにこのタグに精通しています。<rich:tabPanel>の例では、このタグを使用してさまざまなタブを作成しました。次の例では、2つのタグを作成しました。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<ui:composition xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<f:view>
<h:head>
<title>Rich Faces Tab Example</title>
</h:head>
<h:body>
<h:form>
<rich:panel style = "width:60%">
<rich:tabPanel switchType = "AJAX">
<rich:tab header = "Name">
Tutorials Point----This is Tab Number 1
</rich:tab>
<rich:tab header = "Features">
Best Place to learn -------This is Tab Number 2
</rich:tab>
</rich:tabPanel>
</rich:panel>
</h:form>
</h:body>
</f:view>
</ui:composition>
上記のコードは、ブラウザで次の出力を生成します。
<rich:panelMenu>
パネルメニューは、開発者がパネル領域内に垂直ドロップダウントグルを作成するのに役立ちます。次の例は、このタグをよりよく理解するのに役立ちます。「richPanelMenu.xhtml」ファイルを作成し、その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Panel Menu example</title>
</h:head>
<h:body>
<h:form id = "form">
<h:panelGrid columns = "2" columnClasses = "cols,cols" width = "400">
<rich:panelMenu style = "width:200px">
<rich:panelMenuGroup label = "Group 1">
<rich:panelMenuItem label = "Database" action = "#{managedBean.subjectList}">
<f:param name = "current" value = "DB"/>
</rich:panelMenuItem>
<rich:panelMenuItem label = "Oracle" action = "#{managedBean.subjectList}">
<f:param name = "current" value = "Oracle"/>
</rich:panelMenuItem>
<rich:panelMenuItem label = "JAVA" action = "#{managedBean.subjectList}">
<f:param name = "current" value = "JAVA"/>
</rich:panelMenuItem>
</rich:panelMenuGroup>
</rich:panelMenu>
</h:panelGrid>
</h:form>
</h:body>
</html>
上記の例に見られるように、panelMenuには、さまざまな方法で役立つ他のいくつかの関連タグが付属しています。<panelGrid>は、パネル内にグリッドを作成するのに役立ちます。<panelMenuGroup>は、データを入力するさまざまなコンポーネントをグループ化するのに役立ちます。<panelMenuItem>は、ブラウザにレンダリングされる実際のアイテムです。「action」属性を使用すると、選択したアイテムに応じてさまざまなアクションメソッドを呼び出すことができます。「label」属性はフロントエンドに値を設定するために使用され、指定されたアクションクラスが呼び出されると、レンダリングされた値がバックエンドに処理されます。
上記のコードは、ブラウザに次の出力を生成します。
<rich:TogglePanel>
このタグは、Toggle制御メソッドを使用して切り替えまたは切り替えることができるさまざまな出力をレンダリングするために使用されます。このトグル制御方法は、実装またはカスタマイズできます。次の例では、このメソッドを実装します。
xhtmlファイルを作成し、「richTogglePanel.xhtml」という名前を付けます。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Rich Toggle Panel Example</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form id = "form">
<rich:togglePanel id = "panel1" activeItem = "item1"
itemChangeListener = "#{panelMenuBean.updateCurrent}">
<rich:togglePanelItem name = "item1">
<p>Content of the toggle 1</p>
</rich0:togglePanelItem>
<rich:togglePanelItem name = "item2">
<p>Content of the toggle 2</p>
</rich:togglePanelItem>
</rich:togglePanel>
<a4j:outputPanel id = "tabs" layout = "block">
<a4j:outputPanel layout = "block" styleClass = "tabDiv">
<rich:toggleControl event = "click" targetPanel = "panel1" targetItem = "item1" />
<a4j:commandButton value = "Toggle1"/>
</a4j:outputPanel>
<a4j:outputPanel layout = "block" styleClass = "tabDiv">
<rich:toggleControl event = "click" targetPanel = "panel1" targetItem = "item2" />
<a4j:commandButton value = "Toggle2"/>
</a4j:outputPanel>
</a4j:outputPanel>
</h:form>
</h:body>
</html>
また、Webサイトの移行を制御するためのBeanクラスを作成する必要があります。次のような「MenuBean.java」クラスを作成します。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ViewScoped;
import org.richfaces.event.ItemChangeEvent;
@ManagedBean
@ViewScoped
public class MenuBean {
private String current;
private boolean singleMode;
public boolean isSingleMode() {
return singleMode;
}
public void setSingleMode(boolean singleMode) {
this.singleMode = singleMode;
}
public String getCurrent() {
return this.current;
}
public void setCurrent(String current) {
this.current = current;
}
public void updateCurrent(ItemChangeEvent event) {
setCurrent(event.getNewItemName());
}
}
上記のコードは、ブラウザで次の出力を生成します。
上記の例では、ユーザーがクリックしたボタンに応じてWebページのコンテンツが変更されます。「updateCurrent()」は、JSイベントのコンテンツを処理し、外出先でWebサイトのコンテンツを設定するメソッドです。
<rich:toolBar>
toolBarは、パネルに水平バーを作成するために使用されます。これは、Webページにトップレベルのメニューを作成するために使用されます。次の例では、Webページでこのタグを使用する方法を学習します。「xhtml」ファイルを作成し、「toolbar.xhml」という名前を付けます。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>ToolBar Example</title>
</h:head>
<h:body>
<rich:panel>
<rich:toolbar height = "26" itemSeparator = "grid">
<rich:toolbarGroup location = "left">
<h:commandButton styleClass = "barsearchbutton"
onclick = "return false;" value = "TAB" />
</rich:toolbarGroup>
<rich:toolbarGroup location = "left">
<h:commandButton styleClass = "barsearchbutton"
onclick = "return false;" value = "TAB2" />
</rich:toolbarGroup>
<rich:toolbarGroup location = "left">
<h:commandButton styleClass = "barsearchbutton"
onclick = "return false;" value = "TAB3" />
</rich:toolbarGroup>
</rich:toolbar>
</rich:panel>
</h:body>
</html>
上記のコードは、ブラウザで次の出力を生成します。
上記の例では、<toolbarGroup>タグを使用して、異なる同じタイプのツールをグループ化します。グループはいくつでも作成できます。場所は、ボタンが配置されるWebページの位置を提供します。
<rich:separator>
名前が示すように、Webページ上のさまざまなコンポーネントを分離するために使用されます。このタグはRichFaces4で抑制されていますが、RichFaces 3をまだ使用している場合は、次のタグを使用できます。
<rich:separator lineType = "beveled" height = "8" width = "75%" align = "center"/>
<p>Here is more examples of different line types:</p>
<rich:separator height = "2" lineType = "dotted"/><br/>
<rich:separator height = "2" lineType = "dashed"/><br/>
<rich:separator height = "4" lineType = "double"/><br/>
<rich:separator height = "2" lineType = "solid"/><br/>
上記の例では、LineTypeは、使用するセパレーターのタイプを決定するのに役立つ属性です。これらのセパレーター名はすべて、本質的にほとんど自己記述的です。
<リッチ:スペーサー>
Spacerは、開発者が2つのコンポーネント間にスペースを提供するのに役立つ自己記述型タグです。このタグは他のタグと一緒にRichFaces4でも抑制されますが、RichFaces 3を使用している場合は、次のコードを使用できます。
<rich:spacer width = "1" height = "5" title = "Here is a spacer..."/>
<rich:modalPanel>
モーダルパネルは、外出先でポップアップを表示するために使用されます。RichFaces 4では、モーダルパネルタグが次のように変更されました。popupPanel。次の例では、それがどのように機能するかを見ていきます。xhtmlファイルを作成し、「PopingUp.xhtml」という名前を付けます。次のコードをその中に配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>ModalPanel and popupPanel</title>
</h:head>
<h:body>
<h:form>
<h:commandButton value = "Click ME">
<rich:componentControl target = "popup" operation = "show" />
</h:commandButton>
<rich:popupPanel id = "popup" modal = "true" autosized = "false"
resizeable = "false">
Hey !!!
How are you?
</rich:popupPanel>
</h:form>
</h:body>
</html>
上記の例では、「ClickMe」ボタンがクリックされたときに次の出力が生成されます。
前の章では、さまざまな入力コンポーネントと出力コンポーネントについて学習しました。この章では、Webサイトのさまざまなデータ構造を反復処理する方法を学習します。
<rich:dataTable>
このタグは、Webサイトで結果としてテーブルをレンダリングするために使用されます。次の例では、サブジェクトテーブルを効率レベルとともにレンダリングします。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Rich Data Table</title>
</h:head>
<h:body>
<h:form>
<rich:dataTable value = "#{subject.subjectListObj}" var = "record" >
<f:facet name = "header">
<h:outputText value = "My Profile" />
</f:facet>
<rich:column>
<f:facet name = "header">Subject Name</f:facet>
<h:outputText value = "#{record.subjectName}"/>
</rich:column>
<rich:column>
<f:facet name = "header">efficiency Level</f:facet>
<h:outputText value = "#{record.efficiency}"/>
</rich:column>
</rich:dataTable>
</h:form>
</h:body>
</html>
リストをレンダリングするには、それに応じてsubject.javaを変更する必要があります。以下はsubject.javaの例です。
import java.util.ArrayList;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.ManagedProperty;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class Subject {
String SubjectName;
private String efficiency;
private List<Subject> subjectListObj=new ArrayList<>();
public Subject() {
}
public Subject(String SubjectName,String efficiency ) {
this.SubjectName = SubjectName;
this.efficiency= efficiency;
}
public String getSubjectName() {
return SubjectName;
}
public void setSubjectName(String SubjectName) {
this.SubjectName = SubjectName;
}
public List<Subject> getSubjectListObj() {
subjectListObj.add(new Subject("JAVA","Expert"));
subjectListObj.add(new Subject("DOTNET","NA"));
subjectListObj.add(new Subject("JAVA Script","Expert"));
subjectListObj.add(new Subject("Web Service","Expert"));
subjectListObj.add(new Subject("Consulting","Expert"));
return subjectListObj;
}
public void setSubjectListObj(List<Subject> subjectListObj) {
this.subjectListObj = subjectListObj;
}
public String getEfficiency() {
return efficiency;
}
public void setEfficiency(String efficiency) {
this.efficiency = efficiency;
}
}
上記の例では、ブラウザに次の出力が生成されます。
<リッチ:dataDefinitionList>
これは、モデルからデータ定義を生成するために使用されるタグです。RichFaces 4の発明以来、このタグはJBossでサポートされていません。RichFaces3をまだ使用している場合は、次の方法でこのタグを使用できます。
<rich:dataDefinitionList var = "car" value = "#{dataTableScrollerBean.allCars}"
rows = "5" first = "4" title = "Cars">
<f:facet name = "term">
<h:outputText value = "#{car.make} #{car.model}"></h:outputText>
</f:facet>
<h:outputText value = "Price:" styleClass = "label"></h:outputText>
<h:outputText value = "#{car.price}" /><br/>
<h:outputText value = "Mileage:" styleClass = "label"></h:outputText>
<h:outputText value = "#{car.mileage}" /><br/>
</rich:dataDefinitionList>
上記の例では、「dataTableScrollerBean」は、車のさまざまな値を生成するために使用されるJavaクラスです。これは、<datatable>タグを使用してオブジェクト値の束を設定した前のタグに似ています。
<rich:dataOrderedList>
RichFaces 4は、RichFaces 3から幅広いモデレーションを考案しました。<dataOrderedList>は、リストを順序付けてレンダリングするために使用されるタグです。これもRichFaces4では抑制されています。これは、Javaで実行した場合、オブジェクトまたはリストの順序付けがはるかに簡単で時間もかからないためです。アプリケーションがRichFaces3を使用している場合、このタグは次の方法で使用できます。
<rich:panel style = "width:500px">
<f:facet name = "header">
Using rich:dataOrderedList
</f:facet>
<rich:dataOrderedList value = "#{airlinesBean.airlines}" var = "air">
#{air.name}, #{air.code}
</rich:dataOrderedList>
</rich:panel>
上記の例では、「airlinesBean」は「airlinesBean()」という名前のメソッドを持つJavaBeanクラスです。このメソッドは、「air」タイプのオブジェクトを返します。後で、このairオブジェクトを使用して、さまざまなプロパティをテーブル形式で入力できます。
<rich:dataList>
タグ名が示すように、このタグは順序付けられていないリストをブラウザにレンダリングするために使用されます。ただし、<orderedList>と同様に、このタグも最新バージョンのRichFacesでは抑制されています。次の方法で<a4j:Repeat>タグと<rich:dataTable>タグを使用して、リストをブラウザに簡単にレンダリングできます。
<a4j:repeat value = "#{managedBean.subjectList}" var = "sub">
<h:outputText value = "#{sub}"/>
</a4j:repeat>
上記の例では、「subjectList()」というメソッドの出力であるリストをレンダリングしています。アプリケーションがRichFaces3に組み込まれている場合は、このタグを次のように使用できます。
<rich:panel style = "width:500px">
<f:facet name = "header">
Using rich:dataList
</f:facet>
<rich:dataList value = "#{airlinesBean.airlines}" var = "air">
#{air.name}, #{air.code}
</rich:dataList>
</rich:panel>
<rich:dataGrid>
<datatable>タグを使用すると、リストをテーブルとしてレンダリングできますが、<dataGrid>はオブジェクトまたはリストをレンダリングするのに役立ちます。前の<rich:datatable>の例では、xhtmlページを次のように変更して、同じ出力が何であるかを確認します。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Rich Data Table</title>
</h:head>
<h:body>
<h:form>
<rich:panel>
<rich:dataGrid value = "#{subject.subjectListObj}" var = "record"
columns = "2" elements = "4" first = "1" >
<f:facet name = "header">
<h:outputText value = "My Profile" />
</f:facet>
<rich:panel>
<rich:column>
<f:facet name = "header">Subject Name</f:facet>
<h:outputText value = "#{record.subjectName}"/>
</rich:column>
<rich:column>
<f:facet name = "header">efficiency Level</f:facet>
<h:outputText value = "#{record.efficiency}"/>
</rich:column>
</rich:panel>
</rich:dataGrid>
</rich:panel>
</h:form>
</h:body>
</html>
上記のコードは、ブラウザに次の出力を生成します。
<rich:datascroller>
このタグは、テーブルデータを入力するときにスクロールバーを作成するのに役立ちます。これは、JSFのページネーション機能と非常によく似ています。前のdataTableの例を次の方法で変更します。
<?xml version = '1.0' encoding = 'UTF-8' ?>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Rich Data Table</title>
</h:head>
<h:body>
<h:form>
<rich:dataTable value = "#{subject.subjectListObj}" var = "record"
rows = "3" id = "MyTable">
<f:facet name = "header">
<h:outputText value = "My Profile"/>
</f:facet>
<rich:column>
<f:facet name = "header">Subject Name</f:facet>
<h:outputText value = "#{record.subjectName}"/>
</rich:column>
<rich:column>
<f:facet name = "header">efficiency Level</f:facet>
<h:outputText value = "#{record.efficiency}"/>
</rich:column>
</rich:dataTable>
<rich:dataScroller for = "MyTable" maxPages = "3">
<f:facet name = "first">
<h:outputText value = "1" />
</f:facet>
<f:facet name = "last">
<h:outputText value = "eof" />
</f:facet>
</rich:dataScroller>
</h:form>
</h:body>
</html>
上記の例では、スタイルを追加してルックアンドフィールを向上させることができます。ファセット値が異なる個別の<dataScroller>タグを実装しました。上記のファイルの出力は次のとおりです。テーブルとデータスクローラーを同期するために、stylesheer属性を更新します。
この章では、RichFacesテクノロジーが提供するさまざまな選択コンポーネントについて学習します。
<rich:pickList>
このタグを使用して、入力されたリストから1つの値を選択できます。また、リストコンポーネントを別のリストに追加および削除することもできます。次の例は、これがどのように機能するかを示しています。先に進み、1つのxhtmlファイルを作成し、「pickListExample.xhtml」という名前を付けて、次のコードをその中に配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>PickList Example</title>
</h:head>
<h:body>
<h:form>
<h:outputText value = "Pick List Example"/>
<br/>
<br/>
<rich:pickList value = "#{managedBean.subjectList}"
sourceCaption = "SubjectList"
targetCaption = "Selected Subject"
listWidth = "170px"
listHeight = "120px"
orderable = "true">
<f:selectItems value = "#{managedBean.subjectList}"
itemValue = "#{subject}" itemLabel = "#{subject.subjectName}"/>
</rich:pickList>
</h:form>
</h:body>
</html>
ManagedBean.javaファイルを変更して、xhtmlファイルのリストコンポーネントにデータを入力する必要があります。以下は、変更されたJavaファイルのスナップショットです。
import java.util.Arrays;
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class managedBean {
String message;
String job;
private List<String> SubjectList = Arrays.asList(
"Richface","AJAX","JAVA","JSF","DOTNET","python");
public String getMessage() {
return message;
}
public void setMessage(String message) {
System.out.println("setMessage method is getting called with--"+message);
this.message = message;
}
public String getJob() {
return job;
}
public void setJob(String job) {
System.out.println("setJob method is getting called with--"+job);
this.job = job;
}
public List<String> getSubjectList() {
return SubjectList;
}
public void setSubjectList(List<String> SubjectList) {
this.SubjectList = SubjectList;
}
}
上記のコードは、ブラウザに次の出力を生成します。pickListタグの「value」属性は、Beanクラスの「getSubjectList()」に他なりません。「itemValue」はオブジェクトクラスの省略形であり、対応する「itemLabel」はインスタンス値の名前です。この例では、pickListタグにより、「sourceCaption」と「targetCaption」という名前の2つの別個のリストが自動的に作成されます。属性orderableは、ターゲットリストの選択順序を維持するために使用されます。
<rich:orderingList>
このタグは、リスト全体をレンダリングするために使用されます。<orderingList>は、リスト全体に伝播する関数のようなボタンを自動的に提供し、選択したアイテムの注文に役立ちます。次の例では、「OrderingListExample.xhtml」の次のコードを使用して1つのorderingListを作成します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>OrderingList Example</title>
</h:head>
<h:body>
<h:form>
<h:outputText value = "ordering List Example"/><br/><br/>
<rich:orderingList value = "#{managedBean.subjectList}"
itemValue = "#{subject}"
itemLabel = "#{subject.subjectName}" >
</rich:orderingList>
</h:form>
</h:body>
</html>
異なる表現に異なるタグを使用して同じリストに再度データを入力するため、Beanクラスを変更する必要はありません。前の例のように、ここでも値属性は「getSubjectList()」からのリスト全体を保持します。「itemValue」と「itemLabel」は、それぞれオブジェクトクラスと対応するインスタンス変数の値を保持します。
上記のコードは、ブラウザで次の出力を生成します。
<rich:ListShuttle>
ListShuttleタグはRichFaces3で使用できます。これは、あるリストを介して伝播し、同じ値を別のリストに配置するのに役立ちます。RichFaces 4では、上記のように<rich:pickList>という名前の別の新しいタグで同じ機能を実現できるため、このタグは抑制されています。RichFaces 3.0を使用している場合は、次の方法でこのタグを使用できます。
<rich:listShuttle sourceValue = "#{toolBar.freeItems}"
targetValue = "#{toolBar.items}" var = "items" listsHeight = "150"
sourceListWidth = "130" targetListWidth = "130"
sourceCaptionLabel = "Available Items"
targetCaptionLabel = "Currently Active Items"
converter = "listShuttleconverter">
<rich:column width = "18">
<h:graphicImage value = "#{items.iconURI}"></h:graphicImage>
</rich:column>
<rich:column>
<h:outputText value = "#{items.label}"></h:outputText>
</rich:column>
<a4j:support event = "onlistchanged" reRender = "toolBar" />
<a4j:support event = "onorderchanged" reRender = "toolBar" />
</rich:listShuttle>
このタグを使用するよりもpickListを使用すると、2行のコードを記述するだけでpickListを使用して同じ機能を実現できるため、非常に便利です。
RichFacesは、メニュータイプのマークアップを作成するために使用されるタグの幅広いバージョンを提供します。この章では、ブラウザでメニューを簡単にレンダリングできる古い機能とともに、いくつかの新しい機能について学習します。
<rich:dropDownMenu>
このタグを使用して、開発者はドロップダウンメニューを作成できます。このタグは、Webサイトのヘッダーを作成するのに役立ちます。次の例では、このタグを実際の生活で使用する方法を学習します。1つのファイルを作成し、「DropDownList.xhtml」という名前を付けます。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head></h:head>
<h:body>
<h:form>
<rich:toolbar>
<rich:dropDownMenu>
<f:facet name = "label">
<h:outputText value = "File" />
</f:facet>
<rich:menuItem label = "New" />
<rich:menuItem label = "Open File..." />
<rich:menuItem label = "Close" />
<rich:menuItem label = "Close All" />
</rich:dropDownMenu>
</rich:toolbar>
</h:form>
</h:body>
</html>
上記の例では、1つのツールバーを作成し、そのツールバー内に1つのドロップダウンメニューを作成しています。ドロップダウンメニューはいくつでも作成できます。アクションベースのJS関数を挿入する場合は、属性を「action」として<menuItem>タグ内に実装できます。上記のコードは、ブラウザで次の出力を生成します。
<rich:contextMenu>
このタグは、クライアント側でイベントベースのドロップダウンを生成するのに役立ちます。自動的には機能しません。ユーザーはJSイベントを作成する必要があり、それがそれに応じて機能します。次の例では、レンダリングイメージを作成してから、ユーザーの応答に基づいてJSイベントを作成します。以下はxhtmlファイルです。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>ContextMenu Example</title>
</h:head>
<h:body>
<h:form id = "form">
<h:outputScript>
//<![CDATA[
function resize(pic, coeff) {
var w = Math.round(pic.width * coeff);
var h = Math.round(pic.height * coeff);
if (w > 1 && h > 1 && h<1000 && w<1000) {
pic.width = w;
pic.heigth = h;
}
}
function enlarge(element){
resize(element, 1.1);
}
function decrease(element){
resize(element, 0.9);
}
//]]>
</h:outputScript>
<h:graphicImage value = "http://www.tutorialspoint.com/images/jsf-minilogo.png"
id = "pic" style = "border : 5px solid #E4EAEF"/>
<rich:contextMenu target = "pic" mode = "client" showEvent = "click">
<rich:menuItem label = "Zoom In" onclick =
"enlarge(#{rich:element('pic')});" id = "zin"/>
<rich:menuItem label = "Zoom Out"
onclick = "decrease(#{rich:element('pic')});" id = "zout"/>
</rich:contextMenu>
</h:form>
</h:body>
</html>
上記の例を実行して、レンダリングされた画像を選択します。次のオプション「ズームイン」と「ズームアウト」が表示されます。適切なオプションをクリックすると、必要な機能が画像に適用されます。上記のコードは、ブラウザで次の出力を生成します。
<リッチ:コンポーネントコントロール>
このコンポーネントは、RichFaces環境から他の関数を呼び出したいときはいつでもユーザーフレンドリーです。このタグは、JavaScriptベースのアクションクラスを呼び出すために使用されます。次の例は、このタグの使用方法を示しています。ファイルを作成し、「componentContent.xhtml」ファイルという名前を付けます。その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!--
To change this license header, choose License Headers in Project Properties.
To change this template file, choose Tools | Templates
and open the template in the editor.
-->
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Component Control Example</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:commandButton value = "Call the popup">
<rich:componentControl target = "popup" operation = "show" />
</h:commandButton>
<rich:popupPanel id = "popup" modal = "false" autosized = "true" resizeable = "false">
<f:facet name = "header">
<h:outputText value = "Welcome mesage" />
</f:facet>
<f:facet name = "controls">
<h:outputLink value = "#"
onclick = "#{rich:component('popup')}.hide(); return false;"
style = "color: inherit">
X
</h:outputLink>
</f:facet>
<p>Welcome to RICH FACE tutorial at tutorialspoint.com</p>
</rich:popupPanel>
</h:body>
</html>
上記のコードでは、ID「popup」を使用して「onclick()」関数を呼び出しています。実行すると、「ポップアップを呼び出す」というボタンが表示されます。ボタンをクリックすると、RichFacesは内部でJS関数を呼び出し、ブラウザーに次の出力を提供します。
この章では、RichFacesでのツリー処理について学習します。RichFacesは、ツリーを作成および操作するために必要なすべてのコンポーネントを提供します。
<rich:treeNode>
このタグは、階層ツリーを作成するために使用されます。<treeNode>内に提供される各ノードは、ツリーの子ノードになります。このタグは、<rich:tree>という別のタグとともに使用されます。ツリーの作成に使用しているすべてのインスタンス変数は、これら3つのインターフェースのいずれかを実装する必要があります-org.richfaces.model.TreeNode, org.richfaces.model.TreeDataModel, そして javax.swing.tree.TreeNode。
次の例では、バックエンドから<rich:treeNode>タグを使用してツリーにデータを入力します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>TreeNode Example</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form>
<rich:tree value = "#{tree.populateNode}" var = "tree">
<rich:treeNode>
<rich:treeModelRecursiveAdaptor>
</rich:treeModelRecursiveAdaptor>
<h:outputText value = "#{tree.data}" />
</rich:treeNode>
</rich:tree>
</h:form>
</h:body>
</html>
以下は、実装する関連するJavaクラスです。 “TreeNodeImpl” インターフェース。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
import org.richfaces.model.TreeNodeImpl;
@ManagedBean
@RequestScoped
public class Tree extends TreeNodeImpl {
private Tree stationRoot;
private Tree populateNode;
private Object data;
public Tree() {
super();
}
public Tree(boolean leaf, Object data) {
super(leaf);
this.data = data;
}
public Object getData() {
return data;
}
public Tree getPopulateNode() {
if (populateNode == null) {
String[] List_OF_Node = {
"Frist Node", "Second Node", "Third Node", "Fourth Node", "Fifth Node"};
stationRoot = new Tree(false, "Example Of Tree");
for (int i = 0; i < List_OF_Node.length; i++) {
Tree child = new Tree(true, List_OF_Node[i]);
stationRoot.addChild(i, child);
}
populateNode = new Tree();
populateNode.addChild(0, stationRoot);
}
return populateNode;
}
}
上記のコードは、ブラウザで次の出力を生成します。
<rich:treeModelAdaptor>
このコンポーネントは、マップを入力として受け取り、それを反復処理して、ブラウザーで必要な出力を生成します。再帰マップにデータを入力する必要があるときはいつでも、という別のタグを使用できます<rich:recursiveTreeModelAdaptor>。
次の例は、ブラウザでプロジェクト構造をレンダリングする方法を示しています。RichFaces 3では、これら2つのタグが<rich:treeNodeAdaptor>と<rich:recursiveTreeNodeAdaptor>で使用されます。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Tree Model and Recursive Model Example</title>
</h:head>
<h:body>
<h:form id = "form">
<rich:tree toggleType = "AJAX" var = "item" style = "max-width: 400px">
<rich:treeModelRecursiveAdaptor roots = "#{fileSystemBean.sourceRoots}"
nodes = "#{item.directories}">
<rich:treeNode>
#{item.shortPath}
</rich:treeNode>
<rich:treeModelAdaptor nodes = "#{item.files}">
<rich:treeNode>#{item}</rich:treeNode>
</rich:treeModelAdaptor>
</rich:treeModelRecursiveAdaptor>
</rich:tree>
</h:form>
</h:body>
</html>
この例では、2つの新しいJavaBeanを作成する必要があります。以下は、必要なフォルダー名を保持するBeanクラス「FileSystemBean.java」のコードスニペットです。
import java.util.List;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class FileSystemBean {
private static final String SRC_PATH = "/WEB-INF";
private List<FileSystemNode> srcRoots;
public synchronized List<FileSystemNode> getSourceRoots() {
if (srcRoots == null) {
srcRoots = new FileSystemNode(SRC_PATH).getDirectories();
}
return srcRoots;
}
}
以下は、プロジェクトの必要なリーフノードを保持するBeanクラス「FileSystemNode.java」のコードスニペットです。
import static com.google.common.base.Predicates.containsPattern;
import static com.google.common.base.Predicates.not;
import static com.google.common.collect.Iterables.filter;
import static com.google.common.collect.Iterables.transform;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Set;
import javax.faces.context.ExternalContext;
import javax.faces.context.FacesContext;
import com.google.common.base.Function;
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
public class FileSystemNode {
private static final Function<String, FileSystemNode>
FACTORY = new Function<String, FileSystemNode>() {
public FileSystemNode apply(String from) {
return new FileSystemNode(from.substring(0, from.length() - 1));
};
};
private static final Function<String, String>
TO_SHORT_PATH = new Function<String, String>() {
public String apply(String from) {
int idx = from.lastIndexOf('/');
if (idx < 0) {
return from;
}
return from.substring(idx + 1);
};
};
private String path;
private List<FileSystemNode> directories;
private List<String> files;
private String shortPath;
public FileSystemNode(String path) {
this.path = path;
int idx = path.lastIndexOf('/');
if (idx != -1) {
shortPath = path.substring(idx + 1);
} else {
shortPath = path;
}
}
public synchronized List<FileSystemNode> getDirectories() {
if (directories == null) {
directories = Lists.newArrayList();
Iterables.addAll(directories, transform(filter(
getResourcePaths(), containsPattern("/$")), FACTORY));
}
return directories;
}
public synchronized List<String> getFiles() {
if (files == null) {
files = new ArrayList<String>();
Iterables.addAll(files, transform(filter(
getResourcePaths(), not(containsPattern("/$"))), TO_SHORT_PATH));
}
return files;
}
private Iterable<String> getResourcePaths() {
FacesContext facesContext = FacesContext.getCurrentInstance();
ExternalContext externalContext = facesContext.getExternalContext();
Set<String> resourcePaths = externalContext.getResourcePaths(this.path);
if (resourcePaths == null) {
resourcePaths = Collections.emptySet();
}
return resourcePaths;
}
public String getShortPath() {
return shortPath;
}
}
上記の例では、ブラウザで次の出力が生成されます。
この章では、RichFacesで実装できるさまざまなエラー処理方法について学習します。
サーバー側とクライアント側のエラー処理
アクションクラスベースの例外を処理するには、かなり古いJava手法(try / Catch)を実行する必要があります。クライアント側では、ファイルを1つ追加できます。これにより、クライアント側でエラーが発生するたびにエラーメッセージが表示されます。
クライアント側でエラーを処理するために、次のコードスニペットをweb.xmlに追加できます。
<error-page>
<exception-type>java.lang.Throwable</exception-type>
<location>/error.xhtml</location>
</error-page>
上記の例外は静的例外メッセージのみを提供し、動的例外プロパティを使用するためにJSF「ExceptionHandler」クラスを使用する必要がある場合があることに注意してください。実行時に、RichFacesは入力フィールドを検証するためのいくつかの機能を提供します。これは、アプリケーションの例外の主要な構成要素として使用できます。
新しいファイルを作成し、その中に次のコードを配置します。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html>
<html xmlns = "http://www.w3.org/1999/xhtml"
xmlns:h = "http://java.sun.com/jsf/html"
xmlns:f = "http://java.sun.com/jsf/core"
xmlns:ui = "http://java.sun.com/jsf/facelets"
xmlns:a4j = "http://richfaces.org/a4j"
xmlns:rich = "http://richfaces.org/rich">
<h:head>
<title>Error handling</title>
<meta name = "viewport" content = "width = device-width, initial-scale = 1.0"/>
</h:head>
<h:body>
<h:form id = "form">
<rich:panel>
<f:facet name = "header">
<h:panelGroup>
<h:outputText value = "Student Registration" />
<a4j:status>
<f:facet name = "start">
<h:graphicImage value = "/images/ai.gif" style = "height:12px;width:12px;" alt = "ai" />
</f:facet>
</a4j:status>
</h:panelGroup>
</f:facet>
<h:panelGrid columns = "3">
<h:outputText value = "Name:" />
<h:inputText value = "#{student.name}" id = "name" label = "name">
<f:validateLength minimum = "3" maximum = "8" />
<f:validateRequired />
<rich:validator />
</h:inputText>
<rich:message for = "name" />
<h:outputText value = "Email" />
<h:inputText value = "#{student.email}" id = "email"
validatorMessage = "Ivalid email address">
<f:validateRegex
pattern =
"^(([a-zA-Z0-9_\-\.]+)@([a-zA-Z0-9_\-\.]+)
\.([a-zAZ]{2,5}){1,25})+([;.](([a-zA-Z0-9_\-\.]+)
@([a-zA-Z0-9_\-\.]+)\.([a-zAZ]{2,5}){1,25})+)*$" />
<rich:validator />
</h:inputText>
<rich:message for = "email" />
<h:outputText value = "Age" />
<h:inputText value = "#{student.age}" id = "age" label = "age">
<f:validateLongRange minimum = "18" maximum = "99" />
<rich:validator />
</h:inputText>
<rich:message for = "age" />
</h:panelGrid>
</rich:panel>
</h:form>
</h:body>
</html>
対応するJavaクラスは、次のような通常のBeanクラスである必要があります。
import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;
@ManagedBean
@RequestScoped
public class Student {
private String name;
private String email;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
上記の例では、<h:form>にエラーが発生するたびに、ブラウザに次の出力が表示されます。
リソースの読み込み
RichFacesは、JSFアプリケーションの標準的なリソース処理手順を改善します。これは、ResourceServletを構成するか、リソースの最適化によって実装できます。ResourceServletを構成するには、web.xmlに次のコードを追加する必要があります。
<servlet>
<servlet-name>Resource Servlet</servlet-name>
<servlet-class>org.richfaces.webapp.ResourceServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Resource Servlet</servlet-name>
<url-pattern>/org.richfaces.resources/*</url-pattern>
</servlet-mapping>
JSFアプリケーションで最適化を有効にすることもできます。これにより、さまざまなJavaScriptファイルとCSSファイルが最適化されます。アプリケーションで最適化を実現するには、次のコードを追加する必要があります。
<context-param>
<param-name>org.richfaces.resourceOptimization.enabled</param-name>
<param-value>true</param-value>
</context-param>