如何设置iMatrix平台中列表标签(gridjqGrid)实现动态列表
2014-05-08 14:18
281 查看
动态列表
以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的属性根据需求设定,很多是不需要设定的;
标签中取列表数据在后台需调用下面方法:
@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
或者加入QQ群307599527
相关文章推荐
- QPixmap 和 HBITMAP互转
- Python os.path模块和shutil模块
- NPOI 2.0 创建Excel文件
- yocto
- Application always show “waiting for debugger” on device
- When to use AtomicReference?
- js:获取节点相关的 nodeName,nodeType,nodeValue
- C#/JavaScript/SqlServer 对日期时间的操作整理汇总
- 德州-邱杰
- 索引学习(一)
- ORA-02266: unique/primary keys in table referenced by enabled foreign keys
- 手机照片不小心清除怎么办丨联想系列手机
- HTML标签大全(一)
- iTween补间动画样式图
- FAT12文件系统总结
- Asp.net WebConfig 身份验证 增加针对PHP 验证 Asp.net WebConfig 身份验证 增加 PHP 验证
- 关于codeblock的一些设置
- ONVIF开发经验总结
- C#下点击右键之后自动选择为当前选中的节点
- C语言和JAVA哪个比较好啊