1

我找到了这个JSF 教程,它展示了如何使用分页和排序创建 JSF 表

<%@taglib uri="http://java.sun.com/jsf/core" prefix="f"%>
<%@taglib uri="http://java.sun.com/jsf/html" prefix="h"%>
<%@taglib uri="http://myfaces.apache.org/tomahawk" prefix="t"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<f:view>
    <html xmlns="http://www.w3.org/1999/xhtml">
        <head>
            <title>Effective datatable paging and sorting at DAO level</title>
        </head>
        <body>
            <h:form id="form">

                <%-- The sortable datatable --%>
                <h:dataTable value="#{myBean.dataList}" var="item">
                    <h:column>
                        <f:facet name="header">
                            <h:commandLink value="ID" actionListener="#{myBean.sort}">
                                <f:attribute name="sortField" value="id" />
                            </h:commandLink>
                        </f:facet>
                        <h:outputText value="#{item.id}" />
                    </h:column>
                    <h:column>
                        <f:facet name="header">
                            <h:commandLink value="Name" actionListener="#{myBean.sort}">
                                <f:attribute name="sortField" value="name" />
                            </h:commandLink>
                        </f:facet>
                        <h:outputText value="#{item.name}" />
                    </h:column>
                    <h:column>
                        <f:facet name="header">
                            <h:commandLink value="Value" actionListener="#{myBean.sort}">
                                <f:attribute name="sortField" value="value" />
                            </h:commandLink>
                        </f:facet>
                        <h:outputText value="#{item.value}" />
                    </h:column>
                </h:dataTable>

                <%-- The paging buttons --%>
                <h:commandButton value="first" action="#{myBean.pageFirst}"
                    disabled="#{myBean.firstRow == 0}" />
                <h:commandButton value="prev" action="#{myBean.pagePrevious}"
                    disabled="#{myBean.firstRow == 0}" />
                <h:commandButton value="next" action="#{myBean.pageNext}"
                    disabled="#{myBean.firstRow + myBean.rowsPerPage >= myBean.totalRows}" />
                <h:commandButton value="last" action="#{myBean.pageLast}"
                    disabled="#{myBean.firstRow + myBean.rowsPerPage >= myBean.totalRows}" />
                <h:outputText value="Page #{myBean.currentPage} / #{myBean.totalPages}" />
                <br />

                <%-- The paging links --%>
                <t:dataList value="#{myBean.pages}" var="page">
                    <h:commandLink value="#{page}" actionListener="#{myBean.page}"
                        rendered="#{page != myBean.currentPage}" />
                    <h:outputText value="<b>#{page}</b>" escape="false"
                        rendered="#{page == myBean.currentPage}" />
                </t:dataList>
                <br />

                <%-- Set rows per page --%>
                <h:outputLabel for="rowsPerPage" value="Rows per page" />
                <h:inputText id="rowsPerPage" value="#{myBean.rowsPerPage}" size="3" maxlength="3" />
                <h:commandButton value="Set" action="#{myBean.pageFirst}" />
                <h:message for="rowsPerPage" errorStyle="color: red;" />

                <%-- Cache bean with data list, paging and sorting variables for next request --%>
                <t:saveState value="#{myBean}" />
            </h:form>
        </body>
    </html>
</f:view>

这个表可以在没有Tomahawk库的情况下使用吗?我想尽可能多地使用干净的 JSF?可以仅使用标准 JSF 标记编辑此代码而不更改分页和排序吗?

最良好的祝愿

4

1 回答 1

3

那篇旧文章针对的是 JSF 1.x,并且代码旨在与请求范围的 bean 一起使用。确保请求范围的<t:saveState>bean 保留在下一个 POST 请求中,就像新的 JSF 2.x 视图范围所做的一样(因此标准 JSF 1.x 中还不存在)。会话范围不是一个选项,因为它会导致不直观的行为和“wtf?” 最终用户在多个浏览器窗口/选项卡中打开相同页面的情况,因此每个基于请求的操作都会影响同一页面在另一个窗口/选项卡中的行为,以及当最终用户在它们之间切换并在它们上调用基于请求的操作时.

对于 JSF 2.x,<t:saveState>可以通过将 bean 放入视图范围而不是通过标记它来替换请求范围@ViewScoped

@ManagedBean
@ViewScoped
public class MyBean {
    // ...
}

另请注意,本文使用的是旧的 JSP 视图技术。从 JSF 2.0 开始,Facelets 就继承了这一点。您还想用 Facelets 替换 JSP。通过顶级标记(<html>标记)中通常的 XML 命名空间声明删除这些 JSP 标记库,并将文件从 重命名.jsp.xhtml. 这样您就可以替换JSP<t:dataList><ui:repeat>不存在的。

<ui:repeat value="#{myBean.pages}" var="page">
    ...
</ui:repeat>
于 2012-04-07T19:10:09.673 回答