asp.netgridview的Rowcommand命令中获取行索引的方法总结
2023-06-13 09:14:18 时间
一、通过命令源获取当前行索引。
方法比较多,GridView的Command事件中无法象DataGrid那样直接获取行,
法1,
GridViewRowdrv=((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent));//CommandSource引起事件的命令源,(疑问,根据MSDN说的是GridView,如果这样的话这样操作是错误的,但我得到的确实正确的,那说明得到的是BUtton控件,等待以后查证).
drv.RowIndex
二、通过在RowDataBound事件中把行索引绑定到控件的CommandArgument
由于事件参数GridViewCommandEventArgs并不公开Row属性指示当前行,(DataGridCommandEventArgs公开Item属性以获取当然DataGridItem,不知ASP.NETTeam是如何考虑这一设计的),因此需要一点“技巧”来获取此属性。
其实这是一个早就已知的问题,鉴于CSDN里面每每有人疑惑,这里稍微整理下,便于参阅:
复制代码代码如下:
方法比较多,GridView的Command事件中无法象DataGrid那样直接获取行,
法1,
GridViewRowdrv=((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent));//CommandSource引起事件的命令源,(疑问,根据MSDN说的是GridView,如果这样的话这样操作是错误的,但我得到的确实正确的,那说明得到的是BUtton控件,等待以后查证).
drv.RowIndex
二、通过在RowDataBound事件中把行索引绑定到控件的CommandArgument
由于事件参数GridViewCommandEventArgs并不公开Row属性指示当前行,(DataGridCommandEventArgs公开Item属性以获取当然DataGridItem,不知ASP.NETTeam是如何考虑这一设计的),因此需要一点“技巧”来获取此属性。
其实这是一个早就已知的问题,鉴于CSDN里面每每有人疑惑,这里稍微整理下,便于参阅:
protectedvoidGridView1_RowCommand(objectsender,GridViewCommandEventArgse)
{
introwIndex=-1;
GridViewRowrow=null;
switch(e.CommandName)...{
case"Command1"://模板列
//对于模板列内的按钮,我们需要显示绑定行索引到按钮的CommandArgument属性
//以获取触发事件的行信息
rowIndex=Convert.ToInt32(e.CommandArgument);
row=GridView1.Rows[rowIndex];
DisplayInfo(row,e.CommandName);
//yourcodes
//
break;
case"Command2"://模板列
//同样处于模板列中,但不采用Command1方式,而是通过NamingContrainer属性
//直接获取当前的GridViewRow
ControlcmdControl=e.CommandSourceasControl;//表示触发事件的IButtonControl,保持统一性并便于后续操作,我们这里直接转化为控件基类Control
row=cmdControl.NamingContainerasGridViewRow;
DisplayInfo(row,e.CommandName);
//yourcodes
//
break;
case"Command3"://绑定列
//对于ButtonField列,数据源控件内部自动以适当的项索引值填充CommandArgument属性。
//而无需我们显示绑定其CommandArgument属性
//注意,我们这里无法采用Command2的方式,对于BUttonField触发的事件,
//GridViewCommandEventArgs.CommandSource表示的包含此按钮的GridView
rowIndex=Convert.ToInt32(e.CommandArgument);
row=GridView1.Rows[rowIndex];
DisplayInfo(row,e.CommandName);
//yourcodes
//
break;
}
}
相关文章
- MyWebServer小巧的ASP环境集成软件V3.8.40
- ASP和MSSQL结合:开发数据库程序的利器(aspmssql数据库)
- 在MySQL5中使用ASP搭建数据库连接(asp连接mysql5)
- 解决ASP(图像)上传漏洞的方法
- 用ASP打开远端MDB文件的方法
- 在ASP中连接MySQL数据库的方法,最好的通过ODBC方法
- asp重定向页面的方法总结
- asp分页生成html的程序脚本代码
- asp.net简化接收参数值的函数
- ASP个人网站与动网整合非官方方法
- 提高SQL的执行效率的ASP的五种做法
- CODEPAGE列表与asp应用例子
- ASP+MSSQL2000数据库被批量注入后的解决方法
- asp.net使用for循环实现Datalist的分列显示功能
- ASP.NET页面刷新的实现方法(包括html,js)
- asp统计信息实现代码/文章每日、每周、每月、总访问量的方法
- asp中最新新闻显示new图片的实现代码
- ASP.NET中实现jQueryValidation-Engine的Ajax验证实现代码
- asp.net导出Excel显示中文乱码的解决方法
- 几种判断asp.net中session过期方法的比较
- 使用asp.net的pageDataSource中时索引问题解决方法
- IIS部署asp.net报404错误的解决方法
- ASP.NET中URLRewrite的具体实现方法
- asp.net自定义控件中注册Javascript问题解决方案
- asp.net中IDataParameter调用存储过程的实现方法