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