`
暗夜骑士0376
  • 浏览: 81457 次
  • 性别: Icon_minigender_1
  • 来自: 信阳
社区版块
存档分类
最新评论

<h:dataTable/> <h:commandLink/> 的一种解决方案

阅读更多
当我们使用<h:dataTable/> 里面嵌入<h:commandLink/>的时候,我们会发现当我们点击commandlink的时候是响应后台的方法的。这是什么原因呢?这还要从JSF的六个生命周期来说起。而罪魁祸首就是JSF前面几个周期惹的祸。当我们点击commandLink的时候,他是会提交表单的,但是你的dataTable里的迭代的值,我想JSF应该不能那么聪明的把每个值重新部署回到你的后台的一个List的容器中。反向操作太难了。在前几个阶段,如果你manageBean是RequestScope的阶段。那么他会重新初始化一个view视图,这个时候,如果你的dataTable并不是初始就加载的话。那里么是不能显示的。那么这个<h:comamndLink/>就不能被解析,尽管我们之前已经提交了一个action,但是到更新模型值的时候,你就不能解析到这个控件。所以你看到的就是一个重新刷新的页面。该怎么解决?
一种方案是说把 requestScope 变成 sessionScope 这个确实很简单。而且按照我上面讲的原理也能解释为什么sessionScope能够被执行。但是如果在JSP/Servlet 时候,我们就是只是用一个param就解决问题了。如果我们的所有的数据都是放在sessionScope下,我感觉服务器的负载会很大。
可以说也许很多人会对JSF的周期很是愤怒,很是无可奈何?但是成也萧何,败也萧何。我的解决方案,恰恰是在JSF周期进行解决。但是前提是我们的控制逻辑要写好
解决方案:
假设我们的场景是,每一行的数据都有一个edit的link和一个detail的link
我们要做的就是将<h:comamndLink/> 改为<h:link/> outcome 里面加上我们要加载的数值。然后后台bean的解决代码是
@PostConstruct
public void checkControler()
{
     //首先是请求获得的资源viewId
     String viewId = .....
    //然后根据资源的viewId来获得我们pass的参数beanId
    //然后,我们根据这个beanId 从数据库或者缓存池中获得bean对象。对requestScope的bean对象进行了初始化。
   //然后我们在新的页面上进行显示edit,获得detail的数据
}


我的这种方案,只是解决了点击一个链接的问题,当然如果是一个在本页的操作,我们也是可以执行了,比如说delete操作,JSF在前几个周期的时候 仍然是可以接收到我们传来的beanId的值,但是,然后我们还是在那里将操作进行execute。
这只是我们解决方案,欢迎大家来讨论。毕竟这个<h:dataTable/> 和<h:commandLink/>结合的场景很是常见。
分享到:
评论

相关推荐

    jsf2.0 dataTable单行修改例子

    在JSF 2.0中,`&lt;h:dataTable&gt;`是用于创建表格的标准标签。它需要一个列表或数组作为数据源,通常来自Managed Bean。 1. **数据源**:在你的Managed Bean中,你需要创建一个属性来存储你的数据列表。例如,你可以...

    JSF标签详解(一个不漏).doc

    facet标签用于申明一种特殊的关系,常与h:panelGrid和h:dataTable等标签连用,申明组件为标题或页脚。示例代码: ``` &lt;f:facet name="header"&gt; &lt;h:outputText value="Title"/&gt; &lt;/f:facet&gt; ``` loadBundle load...

    JSF控件详细参考手册

    - **&lt;h:commandLink&gt;**:命令链接。 - **&lt;h:dataTable&gt;**:数据表格。 - **&lt;h:form&gt;**:表单容器。 - **&lt;h:graphicImage&gt;**:图形图像。 - **&lt;h:inputHidden&gt;**:隐藏输入字段。 - **&lt;h:inputSecret&gt;**:密码输入框...

    人事信息管理系统

    &lt;p style="text-align:center"&gt; &lt;h:outputLink value="/faces/add.jsp"&gt;添加一条&lt;/h:outputLink&gt; &lt;h:form&gt; &lt;h:dataTable value="#{loginBean.persons}" var="person" border="5" cellpadding="5" cellspacing...

    JSF中文标签

    - **简单表格**:使用`&lt;h:dataTable&gt;`或`&lt;h:table&gt;`等标签创建基本的表格结构。 - **表头、表尾**:可以使用`&lt;f:facet&gt;`来定义表头和表尾。 - **TableModel类**:用于处理表格数据的模型,提供了更高级的表格功能,...

    Microsoft ADO.NET Step by Step

    &lt;br/&gt; Part III - Manipulating Data &lt;br/&gt;Chapter 6 - The DataSet &lt;br/&gt; &lt;br/&gt;Chapter 7 - The DataTable &lt;br/&gt; &lt;br/&gt;Chapter 8 - The DataView &lt;br/&gt; &lt;br/&gt; Part IV - Using the ADO.NET Objects &lt;br/&gt;Chapter 9 ...

    Richfaces的DateTable

    &lt;h:commandLink value="删除" action="#{bean.deleteItem(item)}" /&gt; &lt;/rich:column&gt; &lt;/rich:datatable&gt; ``` 在这里,`addNewItem`和`deleteItem`是后台Bean中的方法,负责处理数据的添加和删除。 4. **AJAX...

    myfaces标签库

    以上代码展示了如何使用MyFaces标签库中的`&lt;h:outputText&gt;`, `&lt;h:inputText&gt;`, `&lt;h:message&gt;`和`&lt;h:commandButton&gt;`等标签创建一个简单的登录表单。`#{bean.userName}`和`#{bean.password}`通过表达式绑定到后端Bean...

    C# Winform实现导入和导出Excel文件

    本文实例为大家分享了Winform实现导入导出Excel文件... /// &lt;param name=dataTable&gt;数据集&lt;/param&gt; /// &lt;param name=isShowExcle&gt;导出后是否打开文件&lt;/param&gt; /// &lt;returns&gt;&lt;/returns&gt; public static bool DataTable

    C#天气预报控件

    /// &lt;returns&gt;返回支持省直辖市的数据表&lt;/returns&gt; public static DataTable getSupportProvince() /// &lt;summary&gt; /// 通过省/直辖市/市的拼音获取支持的市/县的数据表 /// 返回数据表包含字段Name,CenterName...

    .NET DbHelper 数据访问类(MSSQL Mysql ORACLE)

    /// &lt;returns&gt;DataTable 对象。&lt;/returns&gt; DataTable GetDataTable(string sql, int start, int length); /// &lt;summary&gt; /// 执行Insert、Update、Delete等操作,并返回受影响的记录数。 /// &lt;/summary&gt; /// ...

    jsf的基础

    4. **导航标签**:如`&lt;h:link&gt;`和`&lt;h:commandLink&gt;`,用于链接到其他页面或执行服务器端操作。 5. **数据展示标签**:如`&lt;h:dataTable&gt;`,用于显示数据集。 JSF标签通过绑定到后台Bean的属性,使得UI和数据之间的...

    ASP.net技术内幕

    &lt;br/&gt;11.3.7 使用模板编辑DataGrid控件中的条目 &lt;br/&gt;11.4 小结 &lt;br/&gt;&lt;br/&gt;第12章 操作DataSet &lt;br/&gt;&lt;br/&gt;12.1 理解DataSet &lt;br/&gt;12.1.1 DataSet的元素 &lt;br/&gt;12.1.2 向DataSet添加DataTable &lt;br/&gt;12.1.3 将控件绑定...

    primefaces最新版本使用说明

    &lt;p:dataTable value="#{bean.rows}" var="row"&gt; &lt;p:column&gt; &lt;p:cellEditor&gt; &lt;f:facet name="output"&gt; #{row.name} &lt;/f:facet&gt; &lt;f:facet name="input"&gt; &lt;p:inputText value="#{row.name}" /&gt; &lt;/f:facet&gt; &lt;/p...

    EXCEL导入导出

    /// &lt;param name="Table"&gt;DataTable对象&lt;/param&gt; /// &lt;param name="ExcelFilePath"&gt;Excel文件路径&lt;/param&gt; /// &lt;returns&gt;&lt;/returns&gt; /// &lt;summary&gt; /// 获取指定Excel文件数据表的数据列列表 /// &lt;/summary&gt;...

    使用 JSF 构建数据库驱动的应用程序

    一旦查询结果集准备好,就可以使用JSF组件如`&lt;h:dataTable&gt;`来展示结果。 ```html &lt;h:dataTable value="#{bean.resultSet}" var="row"&gt; &lt;h:column&gt; &lt;f:facet name="header"&gt;Email&lt;/f:facet&gt; #{row.EMAIL} &lt;/h:...

Global site tag (gtag.js) - Google Analytics