获取gridview主键值各个事件中,怎样获取主键值

ASPxGridView嵌套,获取子表主键值,求诸位指点 - ASP.NET当前位置:& &&&ASPxGridView嵌套,获取子表主键值,求诸位指点ASPxGridView嵌套,获取子表主键值,求诸位指点&&网友分享于:&&浏览:69次ASPxGridView嵌套,获取子表主键值,求各位指点周末加班,大清早请教各位了!
通过以下方法绑定了子表信息
&&&&&&&&//绑定子表信息
&&&&&&&&protected&void&dxGDSkuCom_DataBinding(object&sender,&EventArgs&e)
&&&&&&&&&&&&ASPxGridView&dd&=&(ASPxGridView)
&&&&&&&&&&&&string&ItemOuterId&=&dxTxtItemCode.Text.Trim();
&&&&&&&&&&&&string&SkuId&=&dd.GetMasterRowFieldValues("Id").ToString();
&&&&&&&&&&&&
&&&&&&&&&&&&dd.DataSource&=&BusinessProtect.BaseInfo.ItemNew.SkuComInfoExecuteDataSet(ItemOuterId,&SkuId);
获取主表的选中事件:string&OuterId&=&dxGDSku.GetRowValues(dxGDSku.FocusedRowIndex,&"规格编码").ToString();我已经知道了!
现在我想获取被选中的子表某条数据的主键值,怎么获取?请教各位啊!------解决方案--------------------引用:Quote: 引用:
Quote: 引用:
Quote: 引用:
错了,应该是&
ds.Tables["子表名"].Rows[ASPxGridVwQry.FocusedRowIndex]["Id"]
首先谢谢!
可惜这种方法行不通,取主表信息我就是是用你说的这种方法,可以实现:
&string&SkuGuid&=&dxGDSku.GetRowValues(dxGDSku.FocusedRowIndex,&"Guid").ToString();
但是取子表信息的话,这种方法实现不了
你页面的Grid是怎么写的?
我用的是DEV控件,下面是ASPxGridView嵌套HTML代码
&&dx:ASPxGridView&ID="dxGDSku"&&runat="server"&&KeyboardSupport="True"&&Theme="DevEx"&KeyFieldName="ItemOuterId"&&AutoGenerateColumns="False"&style="width:&100%"&ToolTip="规格信息"&
&&&&&&&&&&&&&&&&&&&&&&Settings&&VerticalScrollBarMode="Visible"&VerticalScrollableHeight="300"&&/Settings&
&&&&&&&&&&&&&&&&&&&&&&SettingsPager&AllButton-Visible="true"&AllButton-Text="全部显示"&PageSize="50"&PageSizeItemSettings-Visible="true"&&
&&&&&&&&&&&&&&&&&&&&&&AllButton&Text="显示全部"&Visible="True"&&/AllButton&
&&&&&&&&&&&&&&&&&&&&&&PageSizeItemSettings&Visible="True"&&/PageSizeItemSettings&
&&&&&&&&&&&&&&&&&&&&&&/SettingsPager&
&&&&&&&&&&&&&&&&&&&&&SettingsBehavior&AllowSelectByRowClick="true"&ColumnResizeMode="Control"&AllowSelectSingleRowOnly="True"&&&
&&&&&&&&&&&&&&&&&&&&&/SettingsBehavior&
&&&&&&&&&&&&&&&&&&&&&Columns&
&&&&&&&&&&&&&&&&&&&&&&&&&dx:GridViewCommandColumn&&ShowSelectCheckbox="True"&VisibleIndex="0"&width&=&"30px"&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&&&&&/dx:GridViewCommandColumn&
&&&&&&&&&&&&&&&&&&&&&&&&&dx:GridViewDataTextColumn&FieldName&="SkuOuterId"&&Caption="规格编码"&&VisibleIndex="6"&&width&=&"70px"&
&&&&&&&&&&&&&&&&&&&&&&&&&/dx:GridViewDataTextColumn&
&&&&&&&&&&&&&&&&&&&&&/Columns&
&&&&&&&&&&&&&&&&&&&&&&Templates&
&&&&&&&&&&&&&&&&&&&&&&&&DetailRow&
&&&&&&&&&&&&&&&&&&&&&&&&&dx:ASPxGridView&ID="dxGDSkuCom"&runat="server"&KeyFieldName="SkuOuterId"&KeyboardSupport="True"&&Theme="DevEx"&&Width="100%"&
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&OnDataBinding="dxGDSkuCom_DataBinding"&ToolTip="组合信息"&SettingsBehavior-AllowSelectSingleRowOnly="True"&SettingsBehavior-AllowSelectByRowClick="True"& 共&3&页:
12345678910
12345678910
12345678910 上一篇:下一篇:文章评论相关解决方案 12345678910 Copyright & &&版权所有TA的最新馆藏GridView 如何获取当前行的索引值 - Makenna‘s Eye - ITeye技术网站
博客分类:
引用
在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作。例如,可以获得当前行某一个控件元素;设置某一元素的值等等。下面结合实例介绍几种获得GridView当前行索引值的方法。
① 目的:获取GridView中RowCommand的当前索引行。
② 前台页面:在GridView中添加一模版列,里面添加一个LinkButton控件。
&asp:TemplateField HeaderText="操作"&
&ItemTemplate&
&asp:LinkButton ID="lbtnQianRu" runat="server" CommandName="QianRu"
CommandArgument='&%# Eval("Id") %&'&签入&/asp:LinkButton&
&asp:LinkButton ID="lbtnQianChu " runat="server" CommandName="QianChu"&签出 &/asp:LinkButton&
&/ItemTemplate&
&/asp:TemplateField&
小提示:如果在后台代码中用e.CommandArgument取值的话,前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段。如:
//因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
int id = Convert.mandArgument.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.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值
注意:运用此方法,需要对GridView的DataKeyNames属性进行设置,此例中设置为主键字段。 www.liehuo.net
【方法二】
GridViewRow drv = (GridViewRow)((mandSource).NamingC//此得出的值是表示那行被选中的索引值
int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text); //此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
此外,还有一些方法可以实现获得当前行索引值。
【方法三】在linkbutton控件的Command事件,利用sender的Parent获取GridView中的当前行。
protected void lbtnQianChu_Command(object sender, CommandEventArgs e)
LinkButton lb = (LinkButton)
DataControlFieldCell dcf = (DataControlFieldCell)lb.P
GridViewRow gvr = (GridViewRow)dcf.P //此得出的值是表示那行被选中的索引值
lbtnQianChu.SelectedIndex = gvr.RowI
【方法四】在linkbutton控件的Click事件,获取GridView中的当前行。
protected void LinkButton1_Click(object sender, EventArgs e)
int row = ((GridViewRow)((LinkButton)sender).NamingContainer).RowI
【方法五】如果在模板列中添加一下DropDownList控件,并开启其AutoPostback属性,在DropDownList 的SelectedIndexChanged事件中,获取GridView中的当前行。
下面是SelectedIndexChanged事件的代码摘要:
DropDownList ddl = (DropDownList)
GridViewRow gvr = (GridViewRow)ddl.NamingC
int id = int.Parse(GridView1.DataKeys[gvr.RowIndex][0].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)
DataControlFieldCell dcf = (DataControlFieldCell)chk.P
GridViewRow gvr = (GridViewRow)dcf.P
【方法七】
&asp:GridView ID="gvTest" runat="server"&
&asp:TemplateField&
&ItemTemplate&
DisplayIndex : &%# Container.DisplayIndex %& || DataItemIndex : &%# Container.DataItemIndex %&&br /&
&/ItemTemplate&
&/asp:TemplateField&
&/Columns&
&/asp:GridView&
【方法八】
控件的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
mandArgument = e.Row.RowIndex.ToString();
protected void gvInfo_RowCommand(object sender, GridViewCommandEventArgs e)
if (e.CommandName == "ADD")//我LinkButton的CommandName
int index = Convert.mandArgument);
string aa = gvInfo.Rows[index].Cells[1].Text.ToString();//获取当前行列号为一的值,列号从0开始
文章源自:烈火网,原文:file:///C:/Documents%20and%20Settings/Administrator/桌面/我的文件夹/网上咨询网页/GridView%20如何获取当前行的索引值_ASP-_NET_网络编程_烈火网_关注站长,建设互联网!.htm
浏览: 397884 次
来自: 青岛
文章棒棒哒
很不错 之前打开及时600M的内存
,现在打开只有300兆了 ...
这都行。。。我觉得直接用&a/& + css更方便 ...
不错不错.学习了
[u][/u][i][/i][/b][b][/b][b][/b ...

我要回帖

更多关于 gridview 获取主键 的文章

 

随机推荐