欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

GridView使用学习总结

程序员文章站 2024-02-16 13:42:28
由于asp.net视频比较旧,涉及到的数据绑定控件datagrid在vs2012中已经没有了,取而代之的是gridview。开始觉得视频中的例子没法实现了,其实不然,dat...

由于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(); 
} 

附结果图:

GridView使用学习总结

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