动态列表
以demo中“订单(动态列表)”为例说明:此列表显示的信息包括订单主表的信息和订单子表的信息,其中主表信息是编号为ES_ORDER对应列表的信息,子表的信息是从后台动态取得:
1.列表标签中需增加属性dynamicColumn=””;
<grid:jqGrid gridId="dynamicOrder" url="${ctx}/order/dynamic-order.htm" code="ES_ORDER" pageName="dynamicPage" dynamicColumn="${dynamicColumn}"></grid:jqGrid>
在action中定义变量与其对应:
private List<DynamicColumnDefinition> dynamicColumn=new ArrayList<DynamicColumnDefinition>();
2.进入列表页面时后台action调用方法packagingDynamicColumn(),将动态列表追加的表头信息添加进去,追加子表的表头信息是子表中的某个字段,如下方法:
private void packagingDynamicColumn() throws Exception {
//取得子表字段产品名称,以此字段作为表头
List<Object> productNames=orderManager.getOrderItem();
for(int i=0;i<productNames.size();i++){
// "productName"+i是动态列表中每一列的的id
DynamicColumnDefinition dynamicColumnDefinition=new DynamicColumnDefinition(productNames.get(i)
.toString(),"productName"+i);
//是否可编辑
dynamicColumnDefinition.setEditable(true);
//设置数据类型
dynamicColumnDefinition.setType(DataType.INTEGER);
//设置编辑规则
dynamicColumnDefinition.setEditRules("required:true");
//设置是否合计
dynamicColumnDefinition.setIsTotal(true);
//是否导出true表示导出,false表示不导出,默认为true
dynamicColumnDefinition.setExportable(false);
//是否显示true表示显示,false表示不显示,默认为true
dynamicColumnDefinition.setVisible(false);
//列宽
dynamicColumnDefinition.setColWidth("100");
//编辑时为下拉选
dynamicColumnDefinition.setEdittype(EditControlType.SELECT);
dynamicColumnDefinition.setEditoptions("1:'启用',2:'禁用'");
///编辑时为下拉选时的chang事件
dynamicColumnDefinition.setEventType(EventType.ONCHANGE);
//编辑时给input框增加点击事件
dynamicColumnDefinition.setEventType(EventType.ONCLICK);
//编辑时增加默认值CURRENT_USER_NAME表示当前用户名、CURRENT_LOGIN_NAME表示当前登录名、CURRENT_TIME表示当前时间(yyyy-MM-dd hh:mm:ss)、CURRENT_DATE表示日期(yyyy-MM-dd)dynamicColumnDefinition.setDefaultValue(DefaultValue.CURRENT_USER_NAME); dynamicColumnDefinition.setDefaultValue(DefaultValue.CURRENT_LOGIN_NAME); dynamicColumnDefinition.setDefaultValue(DefaultValue.CURRENT_TIME);
dynamicColumnDefinition.setDefaultValue(DefaultValue.CURRENT_DATE);
dynamicColumn.add(dynamicColumnDefinition);
}
}
上述方法中dynamicColumnDefinition的属性根据需求设定,很多是不需要设定的;
1. 标签中取列表数据在后台需调用下面方法:
@Action("dynamic-order")
public String getDynamicOrder() throws Exception {
dynamicPage=orderManager.search(dynamicPage);
this.renderText(PageUtils.dynamicPageToJson(dynamicPage,new DynamicColumnValues(){
public void addValuesTo(List<Map<String, Object>> result) {
Map<String,DynamicColumnDefinition> dynamicColumnName=mmsUtil.getDynamicColumnName();
//取动态列表的列的id
Set<String> productNames=dynamicColumnName.keySet();
for(Map<String, Object> map:result){
Long orderId=Long.valueOf(map.get("id").toString());
for(String productName:productNames){
DynamicColumnDefinition productValue=dynamicColumnName.get(productName);
//在子表的字段中设置值,这里取的是产品数量
map.put(productName.toString(), orderManager.getProductAmount(productValue.getColName(),orderId));
}
}
}
}));
return null;
}
说明:page转json需要调dynamicPageToJson;
result是主表取出来的每一条数据。
关于标签更详细的资料可以到官网下载:http://www.imatrix.net.cn
如有使用iMatrix平台问题请登录iMatrix平台论坛咨询:
http://bbs.imatrix.net.cn/forum.php?mod=forumdisplay&fid=37