关于GridView使用学习总结

  由于Asp.Net视频比较旧,涉及到的数据绑定控件DataGrid在VS20xx中已经没有了,取而代之的是GridView。开始觉得视频中的例子没法实现了,其实不然,DataGrid里面的功能GridView里一样都不少,只是形式变化了一下,仔细研究一下发现它们是换汤不换药啊。

  (一)DataKeyName属性

  (1)DataKeyNames一般都是用来对当前行做唯一标示的,所以一般为数据库的ID。

  (2)GridView.DataKeys[e.RowIndex],e.RowIndex是获取事件对应的行,GridView.DataKeys[e.RowIndex]就是获取对应行的唯一标示也就是DataKeyNames所指定列的值。

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

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

  /// 实现数据绑定功能 ///

  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(" 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; }

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 yyfangchan@163.com (举报时请带上具体的网址) 举报,一经查实,本站将立刻删除