获取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的代码:

[c-sharp]  view plain copy print ?
  1. "pageGridView" runat="server" AutoGenerateColumns="False" DataKeyNames="info_id"  
  2.           OnRowCommand="pageGridView_RowCommand">  
  3.             
  4.               "info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">  
  5.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  6.                   "Small" />  
  7.                 
  8.               "标题">  
  9.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  10.                     
  11.                       "HyperLink1" CssClass="biao_t" runat="server" Font-Size="Small"  
  12.                           Target="_blank" Text=''  
  13.                           NavigateUrl=''>HyperLink  
  14.                     
  15.                   "Left" />  
  16.                 
  17.               "info_addtime" HeaderText="时间" SortExpression="info_addtime"  
  18.                   DataFormatString="[{0:yyyy-MM-dd}]" HtmlEncode="False">  
  19.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  20.                   "Small" />  
  21.                 
  22.               "删除">  
  23.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  24.                     
  25.                       "CheckBox1" runat="server" />  
  26.                     
  27.                     
  28.                       "chkSelectAll" onclick="ChooseAll()" type="checkbox" name="chkSelectAll">
  29.                           size="2">全选  
  30.                     
  31.                 
  32.               "编辑">  
  33.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  34.                     
  35.                       "HyperLink2" runat="server" CssClass="sh_hr" NavigateUrl=''  
  36.                           Text="编辑">  
  37.                         
  38.                     
  39.                 
  40.             
  41.               "审核状态">  
  42.                   "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  43.                     
  44.                       "Button1" runat="server" Text="Button" CommandArgument=''  
  45.                           CommandName="approval" />  
  46.                     
  47.                 
  48.             
  49.         

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

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

[c-sharp]  view plain copy print ?
  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中添加

[c-sharp]  view plain copy print ?
  1. "info_id" HeaderText="序号" SortExpression="info_id" HtmlEncode="False">  
  2.                    "DarkGoldenrod" Font-Size="Small" ForeColor="White" />  
  3.                    "Small" />  
  4.                  

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

 

 




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


目录
相关文章
|
存储 算法 安全
订单号和 id 列可不可以是同一列?
在分布式场景中,单表已经不能满足我们的需求了,所以用自增 id 的方案也就不合适了。当比如我们进行分表设计时,主键列到底如何生成就成了一个问题,流行的方法是利用像 snowflake 这样的算法计算出一个趋势有序的值作为 id。(当然还有其他多种方法)这样就满足了扩展性和一定程度上解决了检索性能的问题。
订单号和 id 列可不可以是同一列?
为什么要设置主键?
为什么要设置主键?
83 0
|
存储 前端开发 数据库
el-table表格拖动列记住列宽度功能(刷新页面还在)
el-table表格拖动列记住列宽度功能(刷新页面还在)
484 0
|
设计模式 数据库
Access2016删除主键列(图文操作)错误提示:若要删除主键,请在“设计”视图中打开该表并删除主键字段
Access2016删除主键列(图文操作)错误提示:若要删除主键,请在“设计”视图中打开该表并删除主键字段
Access2016删除主键列(图文操作)错误提示:若要删除主键,请在“设计”视图中打开该表并删除主键字段
|
JavaScript
VUE element-ui 之table表格勾选复选框动态带出(将某列的值赋值给指定列)对应列的数据
VUE element-ui 之table表格勾选复选框动态带出(将某列的值赋值给指定列)对应列的数据
1033 0
VUE element-ui 之table表格勾选复选框动态带出(将某列的值赋值给指定列)对应列的数据
DataTable 修改列名 删除列 调整列顺序
DataTable 修改列名 删除列 调整列顺序
223 0
|
存储 数据库 索引