最近做了个功能,DataGrid显示具体内容的时候,根据某列分组。
每个分组具体内容后边,增加一行显示合计信息。
查询数据时,使用了union all将分组数据与明细数据合并起来,使用了排序达到了预期的效果。
绑定数据的时候,为了合计行比较醒目,所以把合并行加粗了,合计列居中。
界面如下图:
DataGrid前台:
<asp:DataGrid ID="dgList" DataKeyField="ID" runat="server" AutoGenerateColumns="False" OnItemDataBound="dgList_ItemDataBound">
<Columns>
<asp:TemplateColumn HeaderText="列1">
<ItemTemplate>
<asp:Label ID="lab_COP_G_NO" runat="server" Text='<%#Eval("COP_G_NO") %>'></asp:Label>
</ItemTemplate>
</asp:TemplateColumn>
DataGrid后台ItemDataBound方法:
protected void dgList_ItemDataBound(object sender, DataGridItemEventArgs e)
{
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
Label lab_COP_G_NO = (Label)e.Item.FindControl("lab_COP_G_NO");
if (lab_COP_G_NO.Text == "合计:")
{
e.Item.Font.Bold = true; ((TableCell)lab_COP_G_NO.Parent).HorizontalAlign = HorizontalAlign.Center;
}
}
}
根据列1内容判断,是"合计:",行加粗显示e.Item.Font.Bold = true;
合计列剧中显示((TableCell)lab_COP_G_NO.Parent).HorizontalAlign = HorizontalAlign.Center;
推荐e.Item.FindControl这种写法,前台使用模板列,这样前台调整列的先后顺序不影响后台的使用。