Java动态拼接datagrid的columns

//构造表头
@Override
public String getDynamicColumns(String dateTime) {
//动态设置最上表头的宽度
int colCount = 2;
//展示钢种表头
String head = "[{title:\"" +"日期:" +  dateTime +"\",\"colspan\":2,\"rowspan\":1,width:100},";

List<Map<String,Object>> workingAreaList = dao.getWorkingArea();
for(int i = 0;i<workingAreaList.size();i++){
String workingAreaCode = (String) workingAreaList.get(i).get("workingAreaCode");
String workingAreaName = (String) workingAreaList.get(i).get("workingAreaName");

//获取当天工区对应的班组个数
int count = dao.getWorkingTeamCount(workingAreaCode) + 1;
colCount += count;
head += "{title:\""+workingAreaName+"\",\"colspan\":"+count+",\"rowspan\":1,width:100},";
}
head += "{title:\"\",\"colspan\":1,\"rowspan\":1,width:100}],";
//报表最上表头
String title = "[{title:\"班组日报表\",align:\"center\",\"colspan\":"+colCount+",\"rowspan\":1}],";

//构建easyui表格Columns属性
String content = "[{field : \"elmtName\",title : \"成本要素\",width : 100},";
content +=  "{field : \"amountMesr\",title : \"单位\",width : 100},";

for (int j = 0; j < workingAreaList.size(); j++) {

String workingAreaName = (String) workingAreaList.get(j).get("workingAreaName");
String workingAreaCode = (String) workingAreaList.get(j).get("workingAreaCode");
content += "{field : \"" + workingAreaName +"\",title : \"合计\",width : 100},";

List<Map<String,Object>> jsonList = dao.getDynamicColumns(workingAreaCode);

for(int i = 0;i<jsonList.size();i++){
String workingTeamName = (String) jsonList.get(i).get("workingTeamName");
content += "{field : \""+workingTeamName+"\",title : \""+workingTeamName+"\",width : 100},";
}
}

content += "]";

String columns = "["+title+head+content+"]";
return columns;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
WPF DataGrid是一种用于显示数据的控件,而DataGrid.Columns则是DataGrid中的列集合。你可以通过设置DataGrid.Columns的Background属性来改变整个列的背景颜色。 在WPF中,你可以使用多种方式来设置DataGrid.Columns的Background属性,包括使用静态资源、绑定属性、使用样式等。以下是一些示例代码: 1. 使用静态资源设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{StaticResource MyBrush}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 2. 使用绑定属性设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}"> <DataGridTextColumn.HeaderStyle> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="{Binding DataContext.Column1HeaderBackground, RelativeSource={RelativeSource AncestorType={x:Type DataGrid}}}" /> </Style> </DataGridTextColumn.HeaderStyle> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> ``` 3. 使用样式设置DataGrid.Columns的Background属性: ``` <DataGrid> <DataGrid.Resources> <Style TargetType="DataGridColumnHeader"> <Setter Property="Background" Value="LightGray" /> </Style> </DataGrid.Resources> <DataGrid.Columns> <DataGridTextColumn Header="Column 1" Binding="{Binding Column1}" /> </DataGrid.Columns> </DataGrid> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值