很多数据经常使用表格来表现,JSF提供<h:dataTable>标签让您得以枚举数据并使用表格方式来呈现,举个实际的例子来看,假设您撰写了以下:
package onlyfun.caterpillar;
public class UserBean { private String name; private String password;
public UserBean() { } public UserBean(String name, String password) { this.name = name; this.password = password; } public String getName() { return name; }
public void setName(String name) { this.name = name; }
public String getPassword() { return password; }
public void setPassword(String password) { this.password = password; } }
package onlyfun.caterpillar;
import java.util.*;
public class TableBean { private List userList; public List getUserList() { if(userList == null) { userList = new ArrayList(); userList.add( new UserBean("caterpillar", "123456")); userList.add( new UserBean("momor", "654321")); userList.add( new UserBean("becky", "7890")); } return userList; } }
在TableBean中,我们假设getUserList()方法实际上是从数据库中查询出UserBean的内容,之后传回List对象,若我们的 faces-config.xml如下:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE faces-config PUBLIC "-//Sun Microsystems, Inc.//DTD JavaServer Faces Config 1.0//EN" "http://java.sun.com/dtd/web-facesconfig_1_0.dtd">
<faces-config> <managed-bean> <managed-bean-name>tableBean</managed-bean-name> <managed-bean-class> onlyfun.caterpillar.TableBean </managed-bean-class> <managed-bean-scope>request</managed-bean-scope> </managed-bean> <managed-bean> <managed-bean-name>userBean</managed-bean-name> <managed-bean-class> onlyfun.caterpillar.UserBean </managed-bean-class> <managed-bean-scope>request</managed-bean-scope> </managed-bean> </faces-config>
我们可以如下使用<h:dataTable>来产生表格数据:
<%@ taglib uri="http://java.sun.com/jsf/html" prefix="h" %> <%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %> <html> <body> <f:view> <h:dataTable value="#{tableBean.userList}" var="user"> <h:column> <h:outputText value="#{user.name}"/> </h:column> <h:column> <h:outputText value="#{user.password}"/> </h:column> </h:dataTable> </f:view> </body> </html>
<h:dataTable>的value值绑定tableBean的userList方法,它会一个一个取出
List中的数据并设定给var设定的user,之后在每一个column中我们可以显示所枚举出的user.name与user.password,程
式的结果会如下所示:

所产生的HTML表格标签如下:
<table>
<tbody>
<tr>
<td>caterpillar</td>
<td>123456</td>
</tr>
<tr>
<td>momor</td>
<td>654321</td>
</tr>
<tr>
<td>becky</td>
<td>7890</td>
</tr>
</tbody>
</table>
<h:dataTable>的value值绑定的对象可以是以下的类型:
- 数组
- java.util.List的实例
- java.sql.ResultSet的实例
- javax.servlet.jsp.jstl.sql.Result的实例
- javax.faces.model.DataModel的实例
|