开发者社区> 嗯哼9925> 正文

获取GridView中RowCommand的当前选中行的索引或主键Id

简介:
+关注继续查看

    这两天一直在考虑如何设置新闻发布系统的文章审核模式。初步思路是通过一个"Button"来控制审核状态,在绑定GridView的时候通过表中的字段isshow来设置"Button"的属性。如果isshow=1, 则  btn.Text = "已审核"; btn.Enabled = false;如果isshow=0,则   btn.Text = "审核";btn.Enabled = true; isshow=0是指文章刚被编辑好,管理员还未审核这篇文章是否正确,当管理员认为无误以后,点击“审核”按钮,将isshow设置为1,这样前台就能看到被审核过的文章。

       下面列出前台aspx中的关于GridView的代码:

  1. <asp:GridView ID="pageGridView" runat="server" AutoGenerateColumns="False" DataKeyNames="info_id"  
  2.           OnRowCommand="pageGridView_RowCommand">  
  3.           <Columns>  
  4.               <asp:BoundField DataField="info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">  
  5.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  6.                   <ItemStyle Font-Size="Small" />  
  7.               </asp:BoundField>  
  8.               <asp:TemplateField HeaderText="标题">  
  9.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  10.                   <ItemTemplate>  
  11.                       <asp:HyperLink ID="HyperLink1" CssClass="biao_t" runat="server" Font-Size="Small"  
  12.                           Target="_blank" Text='<%#DataBinder.Eval(Container.DataItem,"INFO_TITLE")%>'  
  13.                           NavigateUrl='<%#"../eNews/showNews.aspx?info_id="+HttpUtility.UrlEncode(DataBinder.Eval(Container.DataItem,"INFO_ID").ToString())%>'>HyperLink</asp:HyperLink>  
  14.                   </ItemTemplate>  
  15.                   <ItemStyle HorizontalAlign="Left" />  
  16.               </asp:TemplateField>  
  17.               <asp:BoundField DataField="info_addtime" HeaderText="时间" SortExpression="info_addtime"  
  18.                   DataFormatString="[{0:yyyy-MM-dd}]" HtmlEncode="False">  
  19.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  20.                   <ItemStyle Font-Size="Small" />  
  21.               </asp:BoundField>  
  22.               <asp:TemplateField HeaderText="删除">  
  23.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  24.                   <ItemTemplate>  
  25.                       <asp:CheckBox ID="CheckBox1" runat="server" />  
  26.                   </ItemTemplate>  
  27.                   <HeaderTemplate>  
  28.                       <input id="chkSelectAll" onclick="ChooseAll()" type="checkbox" name="chkSelectAll"><font  
  29.                           size="2">全选</font>  
  30.                   </HeaderTemplate>  
  31.               </asp:TemplateField>  
  32.               <asp:TemplateField HeaderText="编辑">  
  33.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  34.                   <ItemTemplate>  
  35.                       <asp:HyperLink ID="HyperLink2" runat="server" CssClass="sh_hr" NavigateUrl='<%#"editNews.aspx?info_id="+HttpUtility.UrlEncode(DataBinder.Eval(Container.DataItem,"INFO_ID").ToString())%>'  
  36.                           Text="编辑">  
  37.                       </asp:HyperLink>  
  38.                   </ItemTemplate>  
  39.               </asp:TemplateField>  
  40.             
  41.               <asp:TemplateField HeaderText="审核状态">  
  42.                   <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  43.                   <ItemTemplate>  
  44.                       <asp:Button ID="Button1" runat="server" Text="Button" CommandArgument='<%#Eval("info_id") %>'  
  45.                           CommandName="approval" />  
  46.                   </ItemTemplate>  
  47.               </asp:TemplateField>  
  48.           </Columns>  
  49.       </asp:GridView>  

      从中我们看出我们绑定了“序号”“标题”“时间”“全选”“编辑”“审核”这一些字段。有些直接就是数据库中的字段,比如“序号”和“时间”。而有些则不是,可能是超链接,也可能是按钮等等。

      下面我们看pageGridView_RowCommand()中的定义:

  1. protected void pageGridView_RowCommand(object sender, GridViewCommandEventArgs e)  
  2.    {  
  3.          
  4.        if(e.CommandName=="approval")  
  5.        {  
  6.            //取ID的值方法一   success  
  7.            GridViewRow drv = ((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值  
  8.            int id = Convert.ToInt32(pageGridView.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值  
  9.   
  10.            //取ID的值方法二   只有当GridView中有info_id字段是才成功  
  11.            GridViewRow drv = ((GridViewRow)(((Button)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值  
  12.            //此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引  
  13.            int id = Convert.ToInt32(pageGridView.Rows[drv.RowIndex].Cells[0].Text);  
  14.   
  15.            //取ID的值方法三  success  
  16.            //因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值  
  17.            int id = Convert.ToInt32(e.CommandArgument.ToString());   
  18.            if (NewsBus.setIsShow(id))  
  19.            {  
  20.                this.Label1.Text = "成功!";  
  21.                this.GridViewBind();  
  22.            }  
  23.            else  
  24.            {  
  25.                this.Label1.Text = "失败!";  
  26.            }  
  27.        }  
  28.    }  

     

      其中方法一和方法三如注释中显示的,都通过了验证,只有方法二情况比较特殊,pageGridView.Rows[drv.RowIndex].Cells[0].Text获得的只是GridView表格中的第“索引”行的第一列,如果我们没有在GridView中添加

  1. <asp:BoundField DataField="info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">  
  2.                    <HeaderStyle BackColor="DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  3.                    <ItemStyle Font-Size="Small" />  
  4.                </asp:BoundField>  

那么就获取不到当前行的主键,所以方法二的应用是有前提的。我们这里就没有添加“序号”列,所以使用了方法三。

 

 

参考文章http://space.itpub.net/12639172/viewspace-483589




本文转自xwdreamer博客园博客,原文链接:http://www.cnblogs.com/xwdreamer/archive/2010/03/28/2297144.html,如需转载请自行联系原作者


版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
sql中添加唯一索引(非主键)
if OBJECT_ID('tempdb..#tem') is not null drop table #tem create table #tem (aa nvarchar(20)) alter table #tem add constraint UQ_aa unique (aa) ...
640 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
30439 0
使用 Instance Tunnel 获取 Maxcompute Instance 的执行结果
本篇将介绍如何使用 Instance Tunnel 来获取 Maxcompute Instance 执行结果。
4992 0
《jQuery Cookbook中文版》——1.14 获取、设置和删除DOM元素属性
除了attr()方法之外,jQuery为使用HTML元素class属性提供了一组很特殊的方法。因为class属性可能包含多个值(例如,class="class1 class2 class3"),所以可以使用这些独特的属性方法管理这些类值。
1094 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
21366 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
23639 0
GridView获取隐藏列的值
最近试着看了一下Asp.Net,以前开发过一些Web的系统,但是后来一直没在搞Web的了,所以Web方面的知识都忘记的差不多了,现在遇到一些问题就记下来,以便日后查看。在GridView里面获取隐藏列的值,有时候一些Key字段不想让用户看见,但是后台又需要使用这个关键字段去做一些操作,如果使用普通的...
723 0
+关注
4715
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载