论坛中最常见的一个问题是 我怎样在 DataGrid 中显示列合计? 我亲自多次为这个问题提供了示例代码因此我想在DotNetJunkies 的标题中提供这么一份指南 在这份指南中你将会学到怎样在 DataGrid 中编程实现对某一列的值进行统计并在 DataGrid 的页脚中显示其合计值这份指南中供下载的示例中包括了 C# 和 Visual BasicNET 两种代码
这份指南的最终结果看起来像这样
从上图可看出
上面所用到的屏幕图片中的 DataGrid 是一个非常典型的 DataGrid 有许多控制 DataGrid 外观的属性它使用两个 BoundColumns 来操作数据但这并不是最重要的做好这项工作真正重要的是使用 DataGridOnItemDataBound 事件这个事件将会触发每次绑定一条记录到 DataGrid你可以为这个事件创建一个事件处理以操作数据记录在这种情况下你将会得到运行时 Price 列的合计值
页脚指的是数据范围的最后一行当这行被限定时在事件句处理你可以得到 Price 列的运行时统计值
实施
首先让我们找到一种方法来操作 Web 窗体输出 这份指南中你将使用一个 Web 窗体 (calcTotalsaspx) 以及一个类代码文件 (calcTotalsaspxcs)这份指南的意图是 类代码将会使用 JustInTime 编译器来编译 这里是 calcTotalsaspx 的代码
AutoGenerateColumns=False CellPadding= CellSpacing= BorderStyle=Solid BorderWidth= Gridlines=None BorderColor=Black ItemStyleFontName=Verdana ItemStyleFontSize=pt HeaderStyleFontName=Verdana HeaderStyleFontSize=pt HeaderStyleFontBold=True HeaderStyleForeColor=White HeaderStyleBackColor=Blue FooterStyleFontName=Verdana FooterStyleFontSize=pt FooterStyleFontBold=True FooterStyleForeColor=White FooterStyleBackColor=Blue OnItemDataBound=MyDataGrid_ItemDataBound ShowFooter=True>
ItemStyleHorizontalAlign=Right HeaderStyleHorizontalAlign=Center />
在 Web 窗体中你使用 @ Page 来直接声明这个页所继承的类代码SRC 属性指明了类代码将使用 JIT 编译器来编译 Web 窗体中的大部分代码样式声明用来使 DataGrid 外观变得更好看
最后指定的属性之一是 OnItemDataBound 属性这个事件将会在 OnItemDataBound 事件发生时被触发
Web 窗体中的 DataGrid (MyGrid) 包含有两个 BoundColumns一个是 Title 另一个是Price 这里将显示 Pubs 数据库(SQL Server)中 Titles 表的 title 及 price 列
忽略代码的定义
类代码在所有的地方都将使用在类代码中你可以操作两个事件Page_Load 事件以及 MyGrid_OnItemDataBound 事件还有一个私有方法 CalcTotal 用它来简单的完成运行时统计的数学运算
类代码基本结构块的起始部分
using Systemusing SystemWebusing SystemWebUIusing SystemWebUIWebControlsusing SystemWebUIHtmlControlsusing SystemDatausing SystemDataSqlClient
namespace myApp { public class calcTotals Page { protected DataGrid MyGridprivate double runningTotal = }
在类代码的基本结构中你必须使用相关语句导入名字空间(namespace)在类声明中你声明了两个变量一个是类代码中映射 Web 窗体的 DataGrid(MyGrid)控件的变量一个是用来操作 DataGrid 的 Price 列中运行时统计的双精度值
Page_Load 事件
在 Page_Load 事件中你所要做的就是连接到 SQL Server 并执行一个简单的 SqlCommand 你取得了所有 Price 值> 的 title 和 price 数据你使用 SqlCommandExecuteReader 方法返回一个 SqlDataReader 并将其直接绑定到 DataGrid (MyGrid)
protected void Page_Load(object sender EventArgs e)
{ SqlConnection myConnection = new SqlConnection(server=Localhostdatabase=pubsuid=sapwd=)//创建SQL连接SqlCommand myCommand = new SqlCommand(SELECT title price FROM Titles WHERE price > myConnection)//创建SQL命令
try { myConnectionOpen()//打开数据库连接MyGridDataSource = myCommandExecuteReader()//指定 DataGrid 的数据源MyGridDataBind()//绑定数据到 DataGrid myConnectionClose()//关闭数据连接} catch(Exception ex)
{ //捕获错误HttpContextCurrentResponseWrite(exToString())}
CalcTotals 方法
CalcTotals 方法用来处理 runningTotal 变量这个值将以字符串形式来传递 你需要将它解析为双精度型然后 runningTotal 变量就成了双精度类型
private void CalcTotal(string _price)
{ try { runningTotal += DoubleParse(_price)} catch { //捕获错误}
MyGrid_ItemDataBound 事件
MyGrid_ItemDataBound 事件在数据源中每行绑定到 DataGrid 时被调用在这个事件处理中你可以处理每一行数据 这里你的目的是你将需要调用 CalcTotals 方法并从 Price 列传递文本并用金额型格式化每一行的 Price 列 并在页脚行中显示 runningTotal 的值
public void MyDataGrid_ItemDataBound(object sender DataGridItemEventArgs e)
{ if (eItemItemType == ListItemTypeItem eItemItemType == ListItemTypeAlternatingItem)
{ CalcTotal( eItemCells[]Text )eItemCells[]Text = stringFormat({c} ConvertToDouble(eItemCells[]Text))} else if(eItemItemType == ListItemTypeFooter )
{ eItemCells[]Text=TotaleItemCells[]Text = stringFormat({c} runningTotal)}
在 MyGrid_ItemDataBound 事件句柄中首先你得使用 ListItemType 判断当前的 DataGridItem 是一个数据项还是AlternatingItem 行如果是数据项你调用 CalcTotals并将 Price 列的值作为参数传递给它然后你以金额格式对 Price 列进行格式化及着色
如果 DataGridItem 是页脚可以用金额格式显示 runningTotal
总结
在这份指南中你学到了怎样使用 DataGridOnItemDataBound 事件来实现运行时对DataGrid 的某一列进行统计使用这个事件你可以创建一个列的合计并可对DataGrid行的页脚进行着色