C# DataGrid根据某列的内容设置行字体加粗 单元…
2018-06-22 07:42:01来源:未知 阅读 ()
最近做了个功能,DataGrid显示具体内容的时候,根据某列分组。
每个分组具体内容后边,增加一行显示合计信息。
查询数据时,使用了union all将分组数据与明细数据合并起来,使用了排序达到了预期的效果。
绑定数据的时候,为了合计行比较醒目,所以把合并行加粗了,合计列居中。
界面如下图:
DataGrid前台:
1 <asp:DataGrid ID="dgList" DataKeyField="ID" runat="server" AutoGenerateColumns="False" OnItemDataBound="dgList_ItemDataBound"> 2 <Columns> 3 <asp:TemplateColumn HeaderText="列1"> 4 <ItemTemplate> 5 <asp:Label ID="lab_COP_G_NO" runat="server" Text='<%#Eval("COP_G_NO") %>'></asp:Label> 6 </ItemTemplate> 7 </asp:TemplateColumn>
DataGrid后台ItemDataBound方法:
1 protected void dgList_ItemDataBound(object sender, DataGridItemEventArgs e) 2 { 3 if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem) 4 { 5 Label lab_COP_G_NO = (Label)e.Item.FindControl("lab_COP_G_NO"); 6 if (lab_COP_G_NO.Text == "合计:") 7 { 8 e.Item.Font.Bold = true; 9 10 ((TableCell)lab_COP_G_NO.Parent).HorizontalAlign = HorizontalAlign.Center; 11 } 12 } 13 }
根据列1内容判断,是"合计:",行加粗显示e.Item.Font.Bold = true;
合计列剧中显示((TableCell)lab_COP_G_NO.Parent).HorizontalAlign = HorizontalAlign.Center;
推荐e.Item.FindControl这种写法,前台使用模板列,这样前台调整列的先后顺序不影响后台的使用。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 根据控件Id得到控件并对该控件进行操作 2020-03-04
- datagrid和repeader控件中替换标识值的方法 2020-03-03
- DataGrid中如何实现超链接 2019-10-18
- 【转载】网站域名备案相关流程介绍 2019-02-28
- DataGridView自动调整行高和行宽 2019-01-08
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash