您的位置:首页 > 其它

如何设置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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: