获取GridView当前行的索引值的方法汇总.doc_第1页
获取GridView当前行的索引值的方法汇总.doc_第2页
获取GridView当前行的索引值的方法汇总.doc_第3页
获取GridView当前行的索引值的方法汇总.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

获取GridView当前行的索引值的方法汇总.txt都是一个山的狐狸,你跟我讲什么聊斋,站在离你最近的地方,眺望你对别人的微笑,即使心是百般的疼痛只为把你的一举一动尽收眼底刺眼的白色,让我明白什么是纯粹的伤害。本文详解GridView控件获取当前行的索引值的 asp:LinkButton ID=lbtnQianRu runat=server CommandName=QianRu CommandArgument=签入 签出 方法,下面结合实例介绍几种获得GridView当前行索引值的方法。实例: 目的:获取GridView中RowCommand的当前索引行。 前台页面:在GridView中添加一模版列,里面添加一个LinkButton控件。代码:小提示:如果在后台代码中用e.CommandArgument取值的话,前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段。如:/因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值 int id = Convert.ToInt32(e.CommandArgument.ToString(); 在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引:【方法一】protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e) if (e.CommandName = QianRu) GridViewRow drv = (GridViewRow)(LinkButton)(e.CommandSource).Parent.Parent); /此得出的值是表示那行被选中的索引值 inf id=Convert.ToInt32(GridView1.DataKeysdrv.RowIndex.Value); /此获取的值为GridView中绑定数据库中的主键值注意:运用此方法,需要对GridView的DataKeyNames属性进行设置,此例中设置为主键字段。 【方法二】protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e) if (e.CommandName = QianRu) GridViewRow drv = (GridViewRow)(LinkButton)e.CommandSource).NamingContainer; /此得出的值是表示那行被选中的索引值 int id = Convert.ToInt32(GridView1.Rowsdrv.RowIndex.Cells0.Text); /此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引 此外,还有一些方法可以实现获得当前行索引值。【方法三】在linkbutton控件的Command事件,利用sender的Parent获取GridView中的当前行。protected void lbtnQianChu_Command(object sender, CommandEventArgs e) LinkButton lb = (LinkButton)sender; DataControlFieldCell dcf = (DataControlFieldCell)lb.Parent; GridViewRow gvr = (GridViewRow)dcf.Parent; /此得出的值是表示那行被选中的索引值 lbtnQianChu.SelectedIndex = gvr.RowIndex; 【方法四】在linkbutton控件的Click事件,获取GridView中的当前行。protected void LinkButton1_Click(object sender, EventArgs e) /行号 int row = (GridViewRow)(LinkButton)sender).NamingContainer).RowIndex; 【方法五】如果在模板列中添加一下DropDownList控件,并开启其AutoPostback属性,在DropDownList 的SelectedIndexChanged事件中,获取GridView中的当前行。下面是SelectedIndexChanged事件的代码摘要:DropDownList ddl = (DropDownList)sender; GridViewRow gvr = (GridViewRow)ddl.NamingContainer; int id = int.Parse(GridView1.DataKeysgvr.RowIndex0.ToString(); int num = int.Parse(ddl.Text); 第一句用来获取触发事件的DropDownList控件。第二句就利用该控件的NamingContainer属性,获取其容器,也就是GridViewRow对象。提示:由于DropDoweList与button不同,无法指定其CommandName,所以,通过用NamingContainer属性来解决问题。先来看看微软对该NamingContainer属性的解释:获取对服务器控件的命名容器的引用,此引用创建唯一的命名空间,以区分具有相同 Control.ID 属性值的服务器控件。ASP.NET Web 应用程序的每一页均包含控件的层次结构。此层次结构与控件是否生成用户可见的 UI 无关。给定控件的命名容器是层次结构中该控件之上的父控件,此父控件实现 INamingContainer 接口。实现此接口的服务器控件为其子服务器控件的 ID 属性值创建唯一的命名空间。当针对列表 Web 服务器控件(如 Repeater 和 DataList 服务器控件)进行数据绑定时,为服务器控件创建唯一的命名空间尤其重要。当数据源中的多个项创建服务器控件的多个实例,且该服务器控件是重复控件的子级时,命名容器确保这些子控件的每个实例具有不冲突的 UniqueID 属性值。页的默认命名容器是请求该页时生成的 Page 类的实例。可以使用此属性确定特定服务器控件所在的命名容器。【方法六】如果模板列中有CheckBox控件的情况,通过CheckBox1_CheckedChanged事件中,获取GridView中的当前行。CheckBox chk = (CheckBox)sender; DataControlFieldCell dcf = (DataControlFieldCell)chk.Parent; GridViewRow gvr = (GridViewRow)dcf.Parent; 【方法七】 DisplayIndex : | DataItemIndex : 【方法八】控件的ID和Name命名可以如上方法,我需要通过RowCommand()方法判断选中的是哪一列,而要使用这个方法的前提是,e.CommandArgument这么一个属性(首先必须知道在GridView里,行索引是被放在CommandArgument里面的),现在的任务就是获得这么一个属性。查资料可以知道,在创建GridView控件中每一行时,都将引发一个RowCreated事件,借此这么个方法,可以把linkButton所选择的行号写入CommandArgument中。 protected void gvInfo_RowCreated(object sender, GridViewRowEventArgs e) if (e.Row.RowType = DataControlRowType.DataRow) LinkButton lk1 = (LinkButton)e.Row.FindControl(lkbtn);/LinkButton的ID lk1.CommandArgument = e.Row.RowIndex.ToString(); protected void gvInfo_RowCommand(object sender, GridViewComma

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论