当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > DataGridView中绑定DataTable数据及相关操作实现代码

ASP.NET
asp.net ajax功能强大的UpdatePanel控件
mscorwks.dll在.Net中的地位及代码保护应用
使用.NET实现你的IP切换器
在ADO.NET中用参数化查询缩短开发时间
Login控件:用户登录失败的消息提示
如何用C#来部署数据库
.net打包自动安装数据库
数据库开发个人总结(ADO.NET小结)
ASP.NET如何进行性能优化问题(2)
ASP.NET如何进行性能优化问题(1)
用.Net实现基于CSS的AJAX开发(6)
用.Net实现基于CSS的AJAX开发(5)
用.Net实现基于CSS的AJAX开发(4)
用.Net实现基于CSS的AJAX开发(3)
用.Net实现基于CSS的AJAX开发(2)
用.Net实现基于CSS的AJAX开发(1)
C#下用P2P技术实现点对点聊天
ASP.NET服务器端异步Web方法
在asp.net中如何从视频文件中抓取一桢并生成图像文件
.NET中多线程的同步资源访问

ASP.NET 中的 DataGridView中绑定DataTable数据及相关操作实现代码


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-02-27   浏览: 216 ::
收藏到网摘: n/a

DataGridView中绑定DataTable数据及相关操作
复制代码 代码如下:

DataTable DT = new DataTable();
DT.Columns.Add("Name");
DT.Columns.Add("Sex");
DataRow dr = DT.NewRow();
dr[0] = "Kenny";
dr[1] = "男";
DT.Rows.Add(dr);

A:在DataGridView控件的列编辑中将DataPropertyName属性设为DataTable的列名称,如:DataPropertyName="Name";
B:选中行操作:
复制代码 代码如下:

private void dataGridView_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
if (e.ColumnIndex == 0 && e.RowIndex != -1 && !dataGridView.Rows[e.RowIndex].IsNewRow)
{
String name = dataGridView.Rows[e.RowIndex].Cells["dataGridViewTextBoxColumn1"].Value.ToString();
MessageBox.Show(name);
}
}

e.ColumnIndex指的是你所点击的列的索引,e.RowIndex是行的索引,如果dataGridView没有数据,则e.RowIndex为-1,Cells["dataGridViewTextBoxColumn1"]指的是dataGridView中给列起的名字,也可以用索引表示,写成Cells[0],即第1列.
如果是在web页面的GridView中,需要在GridView要取得值的标签里加入CommandArgument="<%#((GridViewRow)Container).RowIndex %>",并指定CommandName, 通过GridView的FindControl来找到控件,获取控件的值.
代码如下:
asp页面:
复制代码 代码如下:

<asp:LinkButton ID="lkSelect" runat="server" CommandName="Select" CommandArgument="<%#((GridViewRow)Container).RowIndex %>">查看截图</asp:LinkButton>

后台:
在GridView的RowCommand事件里写如下代码:
复制代码 代码如下:

protected void GridView_RowCommand(object sender, GridViewCommandEventArgs e)
{
if (e.CommandName == "Select")
{
int index = Convert.ToInt32(e.CommandArgument); //行索引
GridViewRow row = this.GridView.Rows[index]; //获得GridViewRow的一行
Label label1 = (Label)row.FindControl("label1");
String name = label1.Text;
Response.Write(name);
}
}