Chinaunix首页 | 论坛 | 博客
  • 博客访问: 154451
  • 博文数量: 15
  • 博客积分: 2061
  • 博客等级: 大尉
  • 技术积分: 395
  • 用 户 组: 普通用户
  • 注册时间: 2005-08-06 14:25
文章分类

全部博文(15)

文章存档

2020年(1)

2012年(1)

2009年(7)

2008年(6)

我的朋友

分类: 系统运维

2008-05-10 13:48:30

问题:在使用ECside分页框架的过程中,我们在EC列表页面点击某一行记录,进入该行记录的详细信息页面,此时我们在返回时却又只能返回到第一页,不能返回原来所在的第二页。其中还有原来我们设置好的每页显示多少行,也变回原来的默认值了,排序方式也变成默认的了。
解决方案:在明细页面点击返回时,需要带上几个参数,并且这些参数要用hidden来存储,ECside框架会用request.getParameter()方法来取值。
主要参数如下:
ec_i存储的是EC列表的tableId,该tableId为StrategyListTable
StrategyListTable_crd存储的是每页显示多少行,该参数名是由tableId+"_crd"组成
StrategyListTable_p存储的是当前是第几页,该参数名是由tableId+"_p"组成
StrategyListTable_s_strategyName存储的是用户选择的排序字段和方式,该参数名是由tableId+"_s_"+排序字段 组成,它的value值为asc和desc可选,表示排序方式。
参考实现:在我的参与的项目开发过程中,我们的系统采用Struts+Spring+Hibernate,所有的action都继承自BaseAction,我们直接在这个基类中取出这些参数,再将其传入明细页面,在明细页面只用拷贝几行固定的代码,在返回提交表单的时候,顺便提交一下这些参数就OK了。
BaseAction中的代码:
String ec_i="";
ec_i=req.getParameter("ec_i");

if(ec_i!=null&&!ec_i.equals("")){//存在EC显示属性
String cp=req.getParameter(ec_i+"_p");//取出当前第几页
String crd=req.getParameter(ec_i+"_crd");//取出每页多少行
String sort=req.getParameter("sort");//取出排序方式
String sortProp=req.getParameter("sortProp");//取出排序字段
//判断前台是否有排序信息,如果前台没有排序,则这两个属性都是null
if(sort!=null&&!sort.equals("")&&sortProp!=null&&!sortProp.equals("")){
log.info("原页面取到的排序属性为:"+sortProp+"方式为:"+sort);
req.setAttribute("ECSort", sort);
req.setAttribute("ECSortProp",sortProp);
}
log.info("原页面提交的列表名称为:"+ec_i+" 当前是第 "+cp+" 页,每页显示 "+crd+" 行");
req.setAttribute("ECI", ec_i);
req.setAttribute("ECTable_p", cp);
req.setAttribute("ECTable_crd", crd);
}
明细页面的固定代码:







备注:在项目开发过程中,会有这种情况:从第一个EC列表中点击某行记录进入明细页面,而在这个明细页面中,还有EC列表,在这种情况下,以上这些参数就会重复出现,但ECside框架只会取出其中一个,这时候要注意,在明细页面返回上一个EC列表的时候,要提交上一个EC列表的参数。
阅读(1545) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:XML分析工具的比较

给主人留下些什么吧!~~