• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    GridView使用学习总结

    由于Asp.Net视频比较旧,涉及到的数据绑定控件DataGrid在VS2012中已经没有了,取而代之的是GridView。开始觉得视频中的例子没法实现了,其实不然,DataGrid里面的功能GridView里一样都不少,只是形式变化了一下,仔细研究一下发现它们是换汤不换药啊。
    (一)DataKeyName属性
    (1)DataKeyNames一般都是用来对当前行做唯一标示的,所以一般为数据库的ID。
    (2)GridView.DataKeys[e.RowIndex],e.RowIndex是获取事件对应的行,GridView.DataKeys[e.RowIndex]就是获取对应行的唯一标示也就是DataKeyNames所指定列的值。

    (3)DataList和Repeater是没有的该属性的。

    在代码中这样使用:(定义的该函数在下面都需要调用)

    /// summary> 
    /// 实现数据绑定功能 
    /// /summary> 
    private void BindToDataGird()   
    { 
     SqlConnection con = DB.CreateCon(); 
     SqlDataAdapter sda = new SqlDataAdapter(); 
     sda.SelectCommand = new SqlCommand("select employeeID,FirstName,LastName,Title,BirthDate from employees ", con); 
     DataSet ds = new DataSet(); 
     sda.Fill(ds, "emp");   //将查询到的数据添加到DataSet中。 
     this.GridView1.DataKeyNames =new string[]{ "employeeID"}; //DataKeyNames的使用 
     this.GridView1.DataSource = ds.Tables["emp"];  
     this.DataBind(); 
    } 
    

    如何取值?

    DataKey key = GridView1.DataKeys[e.RowIndex];//其中e为GridViewDelete(或者Edit)EventArgs e 
    string empID = key[0].ToString(); 


    (二)分页
    由于GridView中封装了分页的功能。这里实现起来很容易。先需要设置属性:AllowPaging/PageSize/PageSetting。然后编写事件代码:

    protected void GridView1_PageIndexChanging(object sender, GridViewPageEventArgs e) 
    { 
     this.GridView1.PageIndex = e.NewPageIndex; 
     this.BindToDataGird(); 
    } 


    (三)排序
    首先设置AllowSorting属性为true.事件代码:

    protected void GridView1_Sorting(object sender, GridViewSortEventArgs e) 
    { 
     if (ViewState["order"] == null)  //使用ViewState设置双向排序。 
     { 
      ViewState["order"] = "ASC"; 
     } 
     else 
     { 
      if (ViewState["order"].ToString() == "ASC") 
      { 
       ViewState["order"] = "DESC"; 
      } 
      else 
      { 
       ViewState["order"] = "ASC"; 
      } 
     } 
     //数据绑定显示 
     SqlConnection con = DB.CreateCon(); 
     SqlDataAdapter sda = new SqlDataAdapter(); 
     sda.SelectCommand = new SqlCommand("select employeeID,FirstName,LastName,Title,BirthDate from employees ", con); 
     DataSet ds = new DataSet(); 
     sda.Fill(ds, "emp"); 
     ds.Tables["emp"].DefaultView.Sort = e.SortExpression + " " + ViewState["order"].ToString(); //设置排序 
     this.GridView1.DataSource = ds.Tables["emp"].DefaultView; //将表的默认视图作为数据源。 
     this.DataBind(); 
    } 


    (四)删除
    这里需要注意一点:就是获取某一行的主键值。

    protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e) 
    { 
     DataKey key = GridView1.DataKeys[e.RowIndex]; 
     string empID = key[0].ToString(); 
     SqlConnection con = DB.CreateCon(); 
     SqlCommand cmd = new SqlCommand("delete from employees where employeeID= '"+empID+"'" , con); 
     con.Open(); 
     cmd.ExecuteNonQuery(); 
     this.BindToDataGird(); 
    } 
    

    (五)编辑(更新和取消)

    protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e) 
    { 
     this.GridView1.EditIndex = e.NewEditIndex; 
     this.BindToDataGird(); 
    } 
    protected void GridView1_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e) 
    { 
     this.GridView1.EditIndex = -1; //设置索引值为负取消编辑。 
     this.BindToDataGird(); 
    } 
    protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e) 
    { 
     DataKey key = GridView1.DataKeys[e.RowIndex]; 
     string empID = key[0].ToString(); 
     string lastName=((TextBox)(GridView1.Rows [e.RowIndex ] .Cells [2].Controls [0])).Text ; //将GridView中某列中控件强制转换为TextBox,然后取出它的值。 
     Response.Write(empID +"" + lastName ); //用于测试。 
     this.GridView1.EditIndex = -1; 
     this.BindToDataGird(); 
    } 
    

    附结果图:

    小结:数据绑定控件:Reapter/DataList/GridView的功能成递增关系,都使用到了模板。所以掌握模板很重要。视频使用模板大都是使用控件,不是代码。总感觉这里需要学习的地方还有很多。需要做例子巩固使用。

    您可能感兴趣的文章:
    • GridView自动增加序号(三种实现方式)
    • C#处理datagridview虚拟模式的方法
    • C#中datagridview的EditingControlShowing事件用法实例
    • C#中GridView动态添加列的实现方法
    • C#实现DataGridView控件行列互换的方法
    • C#实现绑定DataGridView与TextBox之间关联的方法
    • C#中DataGridView常用操作实例小结
    • C#实现3步手动建DataGridView的方法
    • asp.net中GridView数据鼠标移入显示提示信息
    • C#中DataGridView动态添加行及添加列的方法
    • 如何用jQuery实现ASP.NET GridView折叠伸展效果
    • ASP.NET GridView中加入RadioButton不能单选的解决方案
    • DataGridView展开与收缩功能实现
    • GridView控件如何显示序号
    上一篇:ASP.NET MVC5网站开发显示文章列表(九)
    下一篇:ASP.NET窗体身份验证详解
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    GridView使用学习总结 GridView,使用,学习,总结,