好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

在Gridview控件中点击编辑链接,把这一行数据传给编辑界面进行修改

在Gridview控件中点击编辑链接,把这一行数据传给编辑界面进行修改

在Gridview控件中点击编辑链接,把这一行数据传给编辑界面进行修改

前台设计部分截图如下:

请看到上图“编辑”这一列,就是今天所说的内容。通过点击编辑链接,将GridView控件这一行的数据加载到编辑页面中,而后就可以进行您所需要的修改了。编辑列,前台代码示例如下:

<asp:TemplateField HeaderText= "  编辑  "  runat= "  server  " >
                                <ItemTemplate>
                                    <asp:LinkButton ID= "  LinkButtonUpdate  "  CommandName= "  cmdUpdate  "  runat= "  server  "  CommandArgument= '  <%#Eval("id")+","+Eval("name")+","+Eval("tname")+","+Eval("ip")+","+Eval("port")+","+Eval("time")+","+Eval("location")+","+Eval("misc")%>  ' >编辑</asp:LinkButton>
                                </ItemTemplate>
                            </asp:TemplateField>

编辑链接的属性CommandArgument有多个参数,其实就是GridView控件中各个列的值。利用GridView控件的RowCommand事件将值传到编辑界面。

         ///   <summary> 
         ///   获取GridView当前数据的行
          ///   </summary> 
         ///   <param name="sender"></param> 
         ///   <param name="e"></param> 
         protected   void  GridView_RowCommand( object   sender, GridViewCommandEventArgs e)
        {
              if  (e.CommandName.Equals( "  cmdUpdate  "  ))
            {
                  string [] estr = e.CommandArgument.ToString().Split( '  ,  '  );
                  string  ID = Convert.ToString(estr[ 0  ]);
                  string  NAME = Convert.ToString(estr[ 1  ]);
                  string  TNAME = Convert.ToString(estr[ 2  ]);
                  string  IP = Convert.ToString(estr[ 3  ]);
                  string  PORT = Convert.ToString(estr[ 4  ]);
                  string  TIME = Convert.ToString(estr[ 5  ]);
                  string  LOCATION = Convert.ToString(estr[ 6  ]);
                  //  string INSTALLTIME = Convert.ToString(estr[6]); 
                 string  MISC = Convert.ToString(estr[ 7  ]);

                Response.Redirect(  "  Modify_Registration.aspx?id=  "  + ID +  "  &name=  "  + NAME +  "  &tname=  "  + TNAME +  "  &ip=  "  + IP +  "  &port=  "  + PORT +  "  &time=  "  + TIME +  "  &location=  "  + LOCATION +  "  &misc=  "  + MISC,  false  );
            }
         } 

上面的代码就是将GridView控件的行数据值绑定到后台,通过Response.Redirect()跳转再将值传到编辑页面中的各个控件中。需要在编辑页面的后台代码Page_Load()方法中加载这些被传过来的数据,

 protected   void  Page_Load( object   sender, EventArgs e)
        {
              if  (! Page.IsPostBack)
            {
                  if  (Request.QueryString[ "  id  " ] !=  null  && Request.QueryString[ "  id  " ].ToString().Trim() !=  ""  )
                {
                      this .txtid.Text = Request.QueryString[ "  id  "  ].ToString().Trim();
                      this .txtname.Text = Request.QueryString[ "  name  "  ].ToString().Trim();
                      this .DropDownList_tname.Text = Request.QueryString[ "  tname  "  ].ToString().Trim();
                      this .txtip.Text = Request.QueryString[ "  ip  "  ].ToString().Trim();
                      this .txtport.Text = Request.QueryString[ "  port  "  ].ToString().Trim();
                      this .txttime.Text = Request.QueryString[ "  time  "  ].ToString().Trim();
                      this .txtlocation.Text = Request.QueryString[ "  location  "  ].ToString().Trim();
                      //  this.Calendarinstalltime.NextMonthText = Request.QueryString["installtime"].ToString().Trim(); 
                     this .txtmisc.Text = Request.QueryString[ "  misc  "  ].ToString().Trim();
                }
                BindData_TypeName();
            }
        } 

如点击编号为“19”的那一行数据,在编辑页面的显示效果为,

这就是今天所讲的效果,值传过来之后,就可以按自己的需求更改,将数据更新到后台数据库中。。。

一家之言,仅供参考!!!

 

 

分类:  ASP.NET

作者: Leo_wl

    

出处: http://www.cnblogs.com/Leo_wl/

    

本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

版权信息

查看更多关于在Gridview控件中点击编辑链接,把这一行数据传给编辑界面进行修改的详细内容...

  阅读:43次