Javaプログラミング/Javaプログラミング関連情報

[JSF] データベースとDataTable(4ページ目)

今回は、データベースからのレコード取得と、それを表示するDataTableについて説明しましょう。

執筆者:掌田 津耶乃

DataTableでレコードを一覧表示する


さて、ようやく今日の本題にやってきました。JSPにDataTableを使って、レコード一覧を表示することにしましょう。

<f:view>
  <h:outputText value="JSF Page 1" id="text0"
    style="color: #0000AA; font-size: 18px; font-weight: bold" />
  <br /><br />
  <h:outputText value="これは、AddressDataテーブルの内容です。" id="text1"
    binding="#{page1Bean.text1}" escape="false" />
  <h:dataTable id="table1" value="#{dataTableBean.tableData}" var="record" border="1">
    <h:column>
      <f:facet name="header">
        <h:outputText id="header1" value="ID" />
      </f:facet>
      <h:outputText value="#{record.id }" />
    </h:column>
    <h:column>
      <f:facet name="header">
        <h:outputText id="header2" value="NAME" />
      </f:facet>
      <h:outputText value="#{record.name }" />
    </h:column>
    <h:column>
      <f:facet name="header">
        <h:outputText id="header3" value="MAIL" />
      </f:facet>
      <h:outputText value="#{record.mail }" />
    </h:column>
  </h:dataTable>
</f:view>

データベースにアクセスし、テーブルのレコード一覧を表示する。

<h:dataTable>タグは、内部に</h:column>タグを持っています。これは各コラム(1つ1つのフィールド項目)の内容を指定するためのもので、ここではID、name、memoの3つのフィールドを</h:column>で表示させています。

</h:column>の中には、ヘッダーを表示する<f:facet>タグと、フィールドの値を表示する<h:outputText>タグが用意されています。値の表示は、実は<h:outputText>で行っていたのですね。

この<h:dataTable>では、value="#{dataTableBean.tableData}"という属性で、Beanのプロパティにバインドをし、結果のListを取得しています。このタグは、valueから1つ1つのオブジェクトを取り出しては、var属性で指定した名前の変数に設定し、タグ内に書かれた内容を出力する、といった作業を繰り返し実行します。値を表示する<h:outputText>タグを見ると、value="#{record.id }"というように、<h:dataTable>のvarで指定した変数の中にあるプロパティにバインドしていることがわかるでしょう。

DataTableそのものはそれほど難しくはないのですが、データベースを利用できる状態にまでセットアップするのは大変です。実際に簡単なテーブルなどを作り、DataTableで表示させてみましょう。何度か試してみれば、だいたいの流れはつかめるはずですよ。
【編集部おすすめの購入サイト】
Amazonで Java 関連の書籍をチェック!楽天市場で Java 関連の書籍をチェック!
  • 前のページへ
  • 1
  • 2
  • 3
  • 4
※記事内容は執筆時点のものです。最新の内容をご確認ください。
※OSやアプリ、ソフトのバージョンによっては画面表示、操作方法が異なる可能性があります。

あわせて読みたい

あなたにオススメ

    表示について

    カテゴリー一覧

    All Aboutサービス・メディア

    All About公式SNS
    日々の生活や仕事を楽しむための情報を毎日お届けします。
    公式SNS一覧
    © All About, Inc. All rights reserved. 掲載の記事・写真・イラストなど、すべてのコンテンツの無断複写・転載・公衆送信等を禁じます