GridView使用学习总结
由于Asp .网视频比较旧,涉及到的数据绑定控件数据网格在VS2012中已经没有了,取而代之的是GridView。开始觉得视频中的例子没法实现了,其实不然,数据网格里面的功能显示数据表格(一种控件)里一样都不少,只是形式变化了一下,仔细研究一下发现它们是换汤不换药啊。(一)DataKeyName属性(1)数据主题名称一般都是用来对当前行做唯一标示的,所以一般为数据库的身份证。(2)GridView .数据键[行索引],行索引是获取事件对应的行,GridView .数据键就是获取对应行的唯一标示也就是数据主题名称所指定列的值。
(3)数据列表和中继器是没有的该属性的。
在代码中这样使用:(定义的该函数在下面都需要调用)
///摘要///实现数据绑定功能////摘要私有void bindtodatarbird(){ SqlConnection con=DB .CreateCon();sqldatadapter sda=new sqldatadapter();sda .SelectCommand=new SqlCommand('从员工中选择员工ID、名字、姓氏、头衔、生日,con);数据集ds=新数据集();sda .填充(ds,“电磁脉冲”);//将查询到的数据添加到资料组中这个GridView 1 .DataKeyNames=新字符串[]{ ' employeeID ' };//DataKeyNames的使用这个. GridView1。数据源=ds .表[' EMP '];这个. DataBind();} 如何取值?
DataKey键=GridView1 .DataKeys[e . RowIndex];//其中e为GridViewDelete(或者编辑)EventArgs e字符串empID=key[0]。ToString();(二)分页由于显示数据表格(一种控件)中封装了分页的功能。这里实现起来很容易。先需要设置属性:允许分页/页面大小/页面设置。然后编写事件代码:
受保护的void GridView 1 _ page indexchanging(对象发送者,GridViewPageEventArgs e) { this .GridView 1。页面索引=e .新页面索引;这个. BindToDagIrd();} (三)排序首先设置允许分类属性为没错。事件代码:
受保护的void GridView1 _排序(对象发送方,GridViewSortEventArgs e){ if(视图状态[' order ']==null)//使用视图状态设置双向排序{ ViewState[' order ']=' ASC ';} else { if (ViewState['order']).ToString()==' ASC '){ ViewState[' order ']=' desc ';} else { ViewState[' order ']=' ASC ';} } //数据绑定显示SqlConnection con=DB .CreateCon();sqldatadapter sda=new sqldatadapter();sda .SelectCommand=new SqlCommand('从员工中选择员工ID、名字、姓氏、头衔、生日,con);数据集ds=新数据集();sda .填充(ds,“电磁脉冲”);ds .表[' EMP ']。默认视图。排序表达式' '视图状态['顺序'].ToString();//设置排序这个. GridView1。数据源=ds .表['emp'].DefaultView//将表的默认视图作为数据源这个. DataBind();} (四)删除这里需要注意一点:就是获取某一行的主键值。
受保护的void GridView1_RowDeleting(对象发送方,GridView deleteeventargs e){ DataKey键=GridView 1 .DataKeys[e . RowIndex];字符串empID=键[0]。ToString();SqlConnection con=DB .CreateCon();SqlCommand cmd=new SqlCommand('从员工中删除,其中employeeID='' empID ' ' ',con);con . Open();cmd .execution query();这个. BindToDagIrd();} (五)编辑(更新和取消)
受保护的void GridView1_RowEditing(对象发送者,GridViewEditEventArgs e) { this .GridView 1。EditIndex=e . new EditIndex这个. BindToDagIrd();}受保护的void GridView1 _ RowCancelingEdit(对象发送方,GridView cancelEdIteventargs e){ this .GridView 1。EditIndex=-1;//设置索引值为负取消编辑这个. BindToDagIrd();}受保护的void GridView1_RowUpdating(对象发送方,GridView updateeventargs e){ DataKey键=GridView 1 .DataKeys[e . RowIndex];字符串empID=键[0]。ToString();字符串姓氏=((文本框)(GridView 1 .行[例如,行索引]。单元格[2]。控件[0])。文字;//将显示数据表格(一种控件)中某列中控件强制转换为文本框,然后取出它的值回应。写(empID ' '姓氏);//用于测试这个GridView 1 .EditIndex=-1;这个. BindToDagIrd();} 附结果图:
小结:数据绑定控件:收割者/数据列表/GridView的功能成递增关系,都使用到了模板。所以掌握模板很重要。视频使用模板大都是使用控件,不是代码。总感觉这里需要学习的地方还有很多。需要做例子巩固使用。
版权声明:GridView使用学习总结是由宝哥软件园云端程序自动收集整理而来。如果本文侵犯了你的权益,请联系本站底部QQ或者邮箱删除。