当我们使用<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/>结合的场景很是常见。
分享到:
相关推荐
在JSF 2.0中,`<h:dataTable>`是用于创建表格的标准标签。它需要一个列表或数组作为数据源,通常来自Managed Bean。 1. **数据源**:在你的Managed Bean中,你需要创建一个属性来存储你的数据列表。例如,你可以...
可以使用`<h:dataTable>`来创建一个基本的表格。 示例代码: ```html <h:dataTable value="#{bean.users}" var="user"> <h:column> <f:facet name="header">ID</f:facet> #{user.id} </h:column> <h:column> ...
facet标签用于申明一种特殊的关系,常与h:panelGrid和h:dataTable等标签连用,申明组件为标题或页脚。示例代码: ``` <f:facet name="header"> <h:outputText value="Title"/> </f:facet> ``` loadBundle load...
- **<h:commandLink>**:命令链接。 - **<h:dataTable>**:数据表格。 - **<h:form>**:表单容器。 - **<h:graphicImage>**:图形图像。 - **<h:inputHidden>**:隐藏输入字段。 - **<h:inputSecret>**:密码输入框...
<p style="text-align:center"> <h:outputLink value="/faces/add.jsp">添加一条</h:outputLink> <h:form> <h:dataTable value="#{loginBean.persons}" var="person" border="5" cellpadding="5" cellspacing...
这类标签,如`<h:commandButton>`、`<h:commandLink>`,响应用户操作并触发服务器端的动作。它们可以通过`action`属性绑定到服务器端的处理方法。 ##### 1.5 选择类标签 选择类标签如`<h:selectOneMenu>`、`<h:...
- **简单表格**:使用`<h:dataTable>`或`<h:table>`等标签创建基本的表格结构。 - **表头、表尾**:可以使用`<f:facet>`来定义表头和表尾。 - **TableModel类**:用于处理表格数据的模型,提供了更高级的表格功能,...
<br/> Part III - Manipulating Data <br/>Chapter 6 - The DataSet <br/> <br/>Chapter 7 - The DataTable <br/> <br/>Chapter 8 - The DataView <br/> <br/> Part IV - Using the ADO.NET Objects <br/>Chapter 9 ...
<h:commandLink value="删除" action="#{bean.deleteItem(item)}" /> </rich:column> </rich:datatable> ``` 在这里,`addNewItem`和`deleteItem`是后台Bean中的方法,负责处理数据的添加和删除。 4. **AJAX...
以上代码展示了如何使用MyFaces标签库中的`<h:outputText>`, `<h:inputText>`, `<h:message>`和`<h:commandButton>`等标签创建一个简单的登录表单。`#{bean.userName}`和`#{bean.password}`通过表达式绑定到后端Bean...
本文实例为大家分享了Winform实现导入导出Excel文件... /// <param name=dataTable>数据集</param> /// <param name=isShowExcle>导出后是否打开文件</param> /// <returns></returns> public static bool DataTable
在JSF中,处理表格通常使用`<h:dataTable>`标签,它可以轻松地展示数据集。例如: ```xml <h:dataTable value="#{bean.data}" var="item"> <h:column> <f:facet name="header">标题</f:facet> #{item.column...
/// <returns>返回支持省直辖市的数据表</returns> public static DataTable getSupportProvince() /// <summary> /// 通过省/直辖市/市的拼音获取支持的市/县的数据表 /// 返回数据表包含字段Name,CenterName...
/// <returns>DataTable 对象。</returns> DataTable GetDataTable(string sql, int start, int length); /// <summary> /// 执行Insert、Update、Delete等操作,并返回受影响的记录数。 /// </summary> /// ...
4. **导航标签**:如`<h:link>`和`<h:commandLink>`,用于链接到其他页面或执行服务器端操作。 5. **数据展示标签**:如`<h:dataTable>`,用于显示数据集。 JSF标签通过绑定到后台Bean的属性,使得UI和数据之间的...
<br/>11.3.7 使用模板编辑DataGrid控件中的条目 <br/>11.4 小结 <br/><br/>第12章 操作DataSet <br/><br/>12.1 理解DataSet <br/>12.1.1 DataSet的元素 <br/>12.1.2 向DataSet添加DataTable <br/>12.1.3 将控件绑定...
<p:dataTable value="#{bean.rows}" var="row"> <p:column> <p:cellEditor> <f:facet name="output"> #{row.name} </f:facet> <f:facet name="input"> <p:inputText value="#{row.name}" /> </f:facet> </p...
/// <param name="Table">DataTable对象</param> /// <param name="ExcelFilePath">Excel文件路径</param> /// <returns></returns> /// <summary> /// 获取指定Excel文件数据表的数据列列表 /// </summary>...
一旦查询结果集准备好,就可以使用JSF组件如`<h:dataTable>`来展示结果。 ```html <h:dataTable value="#{bean.resultSet}" var="row"> <h:column> <f:facet name="header">Email</f:facet> #{row.EMAIL} </h:...