asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié)
更新時間:2010年05月20日 01:05:05 作者:
asp.net gridview的Rowcommand命令中獲取行索引的方法總結(jié),需要的朋友可以參考下。
一、通過命令源獲取當前行索引。
方法比較多, GridView 的 Command 事件中無法象 DataGrid 那樣直接獲取行,
法1,
GridViewRow drv = ((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent));//CommandSource 引起事件的命令源,(疑問,根據(jù)MSDN說的是GridView,如果這樣的話這樣操作是錯誤的,但我得到的確實正確的,那說明得到的是BUtton控件,等待以后查證).
drv.RowIndex
二、通過在RowDataBound事件中把行索引綁定到控件的CommandArgument
由于事件參數(shù) GridViewCommandEventArgs 并不公開Row屬性指示當前行,(DataGridCommandEventArgs 公開 Item 屬性以獲取當然 DataGridItem,不知 ASP.NET Team 是如何考慮這一設(shè)計的),因此需要一點“技巧”來獲取此屬性。
其實這是一個早就已知的問題,鑒于CSDN里面每每有人疑惑,這里稍微整理下,便于參閱:
protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
int rowIndex = -1;
GridViewRow row = null;
switch (e.CommandName) ...{
case "Command1": // 模板列
// 對于模板列內(nèi)的按鈕,我們需要顯示綁定行索引到按鈕的 CommandArgument 屬性
// 以獲取觸發(fā)事件的行信息
rowIndex = Convert.ToInt32(e.CommandArgument);
row = GridView1.Rows[rowIndex];
DisplayInfo(row, e.CommandName);
// your codes
//
break;
case "Command2": // 模板列
// 同樣處于模板列中,但不采用 Command1 方式,而是通過 NamingContrainer 屬性
// 直接獲取當前的 GridViewRow
Control cmdControl = e.CommandSource as Control; // 表示觸發(fā)事件的 IButtonControl,保持統(tǒng)一性并便于后續(xù)操作,我們這里直接轉(zhuǎn)化為控件基類 Control
row = cmdControl.NamingContainer as GridViewRow;
DisplayInfo(row, e.CommandName);
// your codes
//
break;
case "Command3": // 綁定列
// 對于 ButtonField 列,數(shù)據(jù)源控件內(nèi)部自動以適當?shù)捻椝饕堤畛?CommandArgument 屬性。
// 而無需我們顯示綁定其 CommandArgument 屬性
// 注意,我們這里無法采用 Command2 的方式,對于 BUttonField 觸發(fā)的事件,
// GridViewCommandEventArgs.CommandSource 表示的包含此按鈕的 GridView
rowIndex = Convert.ToInt32(e.CommandArgument);
row = GridView1.Rows[rowIndex];
DisplayInfo(row, e.CommandName);
// your codes
//
break;
}
}
方法比較多, GridView 的 Command 事件中無法象 DataGrid 那樣直接獲取行,
法1,
GridViewRow drv = ((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent));//CommandSource 引起事件的命令源,(疑問,根據(jù)MSDN說的是GridView,如果這樣的話這樣操作是錯誤的,但我得到的確實正確的,那說明得到的是BUtton控件,等待以后查證).
drv.RowIndex
二、通過在RowDataBound事件中把行索引綁定到控件的CommandArgument
由于事件參數(shù) GridViewCommandEventArgs 并不公開Row屬性指示當前行,(DataGridCommandEventArgs 公開 Item 屬性以獲取當然 DataGridItem,不知 ASP.NET Team 是如何考慮這一設(shè)計的),因此需要一點“技巧”來獲取此屬性。
其實這是一個早就已知的問題,鑒于CSDN里面每每有人疑惑,這里稍微整理下,便于參閱:
復(fù)制代碼 代碼如下:
protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
int rowIndex = -1;
GridViewRow row = null;
switch (e.CommandName) ...{
case "Command1": // 模板列
// 對于模板列內(nèi)的按鈕,我們需要顯示綁定行索引到按鈕的 CommandArgument 屬性
// 以獲取觸發(fā)事件的行信息
rowIndex = Convert.ToInt32(e.CommandArgument);
row = GridView1.Rows[rowIndex];
DisplayInfo(row, e.CommandName);
// your codes
//
break;
case "Command2": // 模板列
// 同樣處于模板列中,但不采用 Command1 方式,而是通過 NamingContrainer 屬性
// 直接獲取當前的 GridViewRow
Control cmdControl = e.CommandSource as Control; // 表示觸發(fā)事件的 IButtonControl,保持統(tǒng)一性并便于后續(xù)操作,我們這里直接轉(zhuǎn)化為控件基類 Control
row = cmdControl.NamingContainer as GridViewRow;
DisplayInfo(row, e.CommandName);
// your codes
//
break;
case "Command3": // 綁定列
// 對于 ButtonField 列,數(shù)據(jù)源控件內(nèi)部自動以適當?shù)捻椝饕堤畛?CommandArgument 屬性。
// 而無需我們顯示綁定其 CommandArgument 屬性
// 注意,我們這里無法采用 Command2 的方式,對于 BUttonField 觸發(fā)的事件,
// GridViewCommandEventArgs.CommandSource 表示的包含此按鈕的 GridView
rowIndex = Convert.ToInt32(e.CommandArgument);
row = GridView1.Rows[rowIndex];
DisplayInfo(row, e.CommandName);
// your codes
//
break;
}
}
相關(guān)文章
Asp.Net數(shù)據(jù)控件引用AspNetPager.dll分頁實現(xiàn)代碼
今天與大家分享一下“Asp.Net數(shù)據(jù)控件引用AspNetPager.dll分頁”首先聲明以下幾點2012-01-01建立自定義的數(shù)據(jù)驅(qū)動的本地化資源provider
本文探討了自定義的本地化資源提供者.如果想用一個可替代系統(tǒng)的資源處理方案,例如把所有的資源放入數(shù)據(jù)庫中,而不是放在分散的資源文件里,你可以自定義一個resource provider.2010-06-06ASP.NET?Core配置設(shè)置之Configuration包
這篇文章介紹了ASP.NET?Core配置設(shè)置之Configuration包,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07Visual Studio 2017+OpenCV環(huán)境搭建教程
這篇文章主要為大家詳細介紹了Visual Studio 2017+OpenCV環(huán)境搭建教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法
這篇文章主要介紹了asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法,結(jié)合實例形式分析了ActionFilterAttribute過濾關(guān)鍵字的原理與相關(guān)實現(xiàn)技巧,需要的朋友可以參考下2016-03-03使用NLog給Asp.Net Core做請求監(jiān)控的方法
這篇文章主要介紹了使用NLog給Asp.Net Core做請求監(jiān)控的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05DataTable轉(zhuǎn)成字符串復(fù)制到txt文本的小例子
DataTable轉(zhuǎn)成字符串復(fù)制到txt文本的小例子,需要的朋友可以參考一下2013-03-03