DataGridView中绑定DataTable数据及相关操作实现代码
2024-07-10 12:42:36
供稿:网友
 
 代码如下: 
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); 
} 
}