当我们使用<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/>结合的场景很是常见。
分享到:
相关推荐
<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...
<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 ...
本文实例为大家分享了Winform实现导入导出Excel文件... /// <param name=dataTable>数据集</param> /// <param name=isShowExcle>导出后是否打开文件</param> /// <returns></returns> public static bool DataTable
/// <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> /// ...
<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 将控件绑定...
/// <returns>DataTable</returns> /// <summary> /// 读取XML资源中指定的DataTable的指定行指定列的值 /// </summary> /// <param name="source">XML资源</param> /// <param name="xmlType">XML资源类型:...
/// <param name="Table">DataTable对象</param> /// <param name="ExcelFilePath">Excel文件路径</param> /// <returns></returns> /// <summary> /// 获取指定Excel文件数据表的数据列列表 /// </summary>...
</h:dataTable> <ems:page id="pageId" for="tableId" maxPage="5" /> 2. 相应的Managedbean: [java] view plaincopy /** * EMS 11185 限时未达邮费奉还 * @author 螃蟹 */ @SuppressWarnings(value ...
提示:<e:menu value="#{menuBean.model}" action="#{menuBean.navigationAction}"></e:menu>中的menuBean是你自己定义的managedbean, 并且要extends EMS11185MenuBean; action="#{menuBean.navigationAction...
/// <param name="fileName">Excel全路径文件名</param> /// <returns>导入成功的DataSet</returns> public DataSet ImportExcel(string fileName) /// <summary> /// 把DataTable导出到EXCEL /// </...
<summary>拼接DataTable,返回ArrayList 数组</summary> <param name="dgv" /> <returns /> <remarks /> </member> - <member name="M:Pic_Chart_Load.file_deal.Create_File_Out_Sql(System.Byte[],System...
一个C#分页存储过程类,参数灵活 /// </summary> /// <param name="gridViewName">表名</param> /// <param name="ProcName">存储过程名</param> /// <param name="fieldName">查询字段</param> /// <param ...
<Control type="DataTable" dataset="datasetCustom" id="tableCustom" width="100%"> <Column field="EMPLOYEE_ID" name="EMPLOYEE_ID"/> <Column field="DEPT_ID" name="DEPT_ID"/> <Column field="EMPLOYEE_...
/// <param name="dt">DataTable</param> /// <param name="strFilePath">物理路径</param> /// <param name="tableheader">表头</param> /// <param name="columname">字段标题,逗号分隔</param> public ...
<br><br>* DataTable Sorting <br>* DataTable Filtering <br>* Calendar month and year manual selection <br>* Objects selection for suggestion box <br>* Standard component skinning <br>* Client-side EL ...
/// <returns><c>true</c>操作成功<c>false</c>操作失败</returns> public bool InsertTable(System.Data.DataTable dt, Excel.Worksheet ws, int startX, int startY) { try { for (int i = 0; i <= dt....
/// <param name=dataTable>数据源</param> /// <param name=AbsoluteExcelFilePath>Excel文件的绝对路径</param> /// <param name=TblColName>TBL里对应的列名</param> /// <param name=ColumnName>E
在项目中只须添加引用cwyExcelXml.dll便可<br><br><br><br><br>cwyCreateExcelXml(System.Data.DataSet ds, string PathFileName, bool isHeader) <br> //功能:把DataSet 类型数据存储为excel 支持的xml格式.(此格式...
窗体打印报表文件 ... /// <param name="TableName">DataTable名称,与创建的DataSet里面的表名称相同</param> /// <param name="list">承载数据的列表</param> /// <param name="param">报表的参数</param>