DataGridView中繫結DataTable資料及相關操作實現程式碼

NO IMAGE

複製程式碼 程式碼如下:
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);
}
}

您可能感興趣的文章:

C# DataGridView新增新行的2個方法WinForm中DataGridView新增,刪除,修改操作具體方法C# DatagridView常用操作彙總DataGridView自動調整行高和行寬c#利用Excel直接讀取資料到DataGridViewc#讀取xml檔案到datagridview例項asp.net DataGridView匯出到Excel的三個方法[親測]C#中DataGridView動態新增行及新增列的方法C# Datagridview繫結List方法程式碼Datagridview使用技巧(9)Datagridview的右鍵選單