分享
 
 
 

ASP.NET:优化DataGrid控件的编辑功能

王朝asp·作者佚名  2006-11-24
窄屏简体版  字體: |||超大  

尽管在上面的实例中我们已经实现了DataGrid的在线编辑功能,但是,如果我们已经习惯了C/S 结构的程序,就会感觉到上个实例中编辑的不足:提交数据频繁,加重了服务器的负担。在这一节中,我们利用一个实例来演示优化后的DataGrid控件的编辑功能,其中的技术就是引入批量更新数据。引入的一个新知识就是控件的FindControl方法。

我们来看具体实例。首先在DataCon Web项目里,添加一个Web Form,命名为DataGrid_Sample6.aspx,然后添加一个DataGrid控件,由于我们做了DataGrid控件的显示模版,并且为了优化其编辑属性,我们特别利用<asp:TemplateColumn ><ItemTemplate></ItemTemplate></asp:TemplateColumn >属性添加了DropDownList控件和CheckBox控件。为了便于实例应用和读者理解,我们新建一个TeacherInfor.mdb数据库,该数据库包含一个teacher数据表 ,字段类型和虚拟数据如图9.11和9.12所示。

图9.11 teacher数据表中的字段属性

图9.12 teacher数据表中数据记录

DataGrid_Sample6.aspx的主要HTML代码如下:

<body topMargin="0" MS_POSITIONING="GridLayout">

<form id="Form1" method="post" runat="server">

<FONT face="宋体"><b>经济管理学院教师信息</b>

<asp:DataGrid id="DataGrid1"

runat="server" AutoGenerateColumns="False" Width="320px" PageSize="4"

AllowPaging="True">

<AlternatingItemStyle BackColor="WhiteSmoke"></AlternatingItemStyle>

<ItemStyle BackColor="GhostWhite"></ItemStyle>

<HeaderStyle BackColor="LightSteelBlue"></HeaderStyle>

<Columns>

<asp:BoundColumn DataField="id" HeaderText="编号"></asp:BoundColumn>

<asp:BoundColumn DataField="name" HeaderText="姓名"></asp:BoundColumn>

<asp:TemplateColumn HeaderText="性别">

<ItemTemplate>

<asp:DropDownList id="sex" runat="server" SelectedIndex='<%# Cint(DataBinder.Eval(Container,"DataItem.sex")) %>' >

<asp:ListItem Value="0">男</asp:ListItem>

<asp:ListItem Value="1">女</asp:ListItem>

</asp:DropDownList>

</ItemTemplate>

</asp:TemplateColumn>

<asp:TemplateColumn HeaderText="所获学位">

<ItemTemplate>

<asp:DropDownList id="degree" runat="server" SelectedIndex='<%# cint(DataBinder.Eval(Container,"DataItem.degree")) %>'>

<asp:ListItem Value="0">学士</asp:ListItem>

<asp:ListItem Value="1">硕士</asp:ListItem>

<asp:ListItem Value="2">博士</asp:ListItem>

</asp:DropDownList>

</ItemTemplate>

</asp:TemplateColumn>

<asp:TemplateColumn HeaderText="性别">

<ItemTemplate>

<asp:DropDownList id="title" runat="server" SelectedIndex='<%# Cint(DataBinder.Eval(Container,"DataItem.title")) %>' >

<asp:ListItem Value="0">讲师</asp:ListItem>

<asp:ListItem Value="1">副教授</asp:ListItem>

<asp:ListItem Value="2">教授</asp:ListItem>

</asp:DropDownList>

</ItemTemplate>

</asp:TemplateColumn>

<asp:TemplateColumn HeaderText="婚否">

<ItemTemplate>

<asp:CheckBox Runat=server Checked ='<%# DataBinder.Eval(Container,"DataItem.marry") %>' ID="marry" Text ="婚否">

</asp:CheckBox>

</ItemTemplate>

</asp:TemplateColumn>

</Columns>

<PagerStyle BackColor="LightSteelBlue" Mode="NumericPages"></PagerStyle>

</asp:DataGrid>

<asp:button id="Button1"

runat="server" Text="批量更新">

</asp:button></FONT>

</form>

</body>

在上面HTML代码中,注意DataGrid控件值的数据绑定:

SelectedIndex='<%# cint(DataBinder.Eval(Container,"DataItem.degree")) %>'

DataGrid_Sample6.aspx.vb中的逻辑代码如下:

'----code begin ----------

'-省略命名空间的引用

Public Class DataGrid_Sample6

Inherits System.Web.UI.Page

#Region " Web 窗体设计器生成的代码 "

'此处省略窗体设计器生成的代码

#End Region

Private Sub Page_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

'在此处放置初始化页的用户代码

If Not IsPostBack Then

getdata()

End If

End Sub

'读取数据

Sub getdata()

Dim mycon As OleDb.OleDbConnection

viewstate("constr") = "provider=microsoft.jet.oledb.4.0;data source=" + Server.MapPath(".") + "\TeacherInfor.mdb"

'使用viewsate保存Connection连接字符串

Dim mycmd As OleDb.OleDbDataAdapter

'声明DataAdapter对象

Dim mysql As String

'声明Command命令的 SQL字符串

Try

mycon = New OleDb.OleDbConnection(viewstate("constr"))

'实例化Connection对象

mysql = "Select id,name, sex ,degree, title,marry from teacher"

'设置SQL语句,即查询数据库中所有内容

mycmd = New OleDb.OleDbDataAdapter(mysql, mycon)

Dim dt As Data.DataSet = New Data.DataSet

'声明DataSet对象,并实例话

mycmd.Fill(dt)

'填充数据,即在内存中生成DataSet模型数据库

DataGrid1.DataSource = dt.Tables(0)

'为DataGrid1控件指定数据源

DataGrid1.DataBind()

'执行绑定

Catch ex As Exception

Response.Write("程序出错,信息描述如下:<br>" & ex.Message)

Finally

mycon.Close()

End Try

End Sub

'翻页事件

Private Sub DataGrid1_PageIndexChanged(ByVal source As Object, ByVal e As System.Web.UI.WebControls.DataGridPageChangedEventArgs) Handles DataGrid1.PageIndexChanged

DataGrid1.CurrentPageIndex = e.NewPageIndex

getdata()

End Sub

'批量更新过程

Pri

[1] [2] 下一页

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有