在Asp.Net中,我们使用最多的恐怕就是DataGrid列表控件了。这个控件的功能的却非常强大,也非常好用。它不但可以实现任意的格式化选择,而且还可以动态进行分页、排序、添加按钮、动态编辑等功能。可以说,DataGrid控件已经实现了我们需要的大部分功能。
DataGrid控件需要通过ViewState来保存控件的状态的,如果我们关闭了ViewState,即在HTML代码中使用了EnableViewState="False"属性,那么,上面的所有有用的功能我们将无法使用。
而ViewState的缺点也是很大的,就是DataGrid会把所有的数据源中的数据存放到ViewState中。我试验了一下,一个包括5000条记录的数据库,如果不在数据库端控制数据量的话,直接使用Select * From TableName这样的Sql语句绑定数据的话,一个Asp.Net动态网页(仅有一个DataGrid控件的测试页)的ViewState有60k之多。而这样一个网页放到公共Web网站,缓慢的网页下载速度将会使大部分人望而却步,使用56k猫上网的人就更不要提了,根本无法访问这样的网页,等待的时间将不可忍受。
DataGrid保存在ViewState中的数据分为两个部分,一部分是保存索引用的,就是DataKeys和DataItems这样的属性使用的数据,我们把它称之为索引数据。还有一部分是DataGrid中数据源的内容,我们称之为列表数据。
我们如果把实际上无用的列表数据从ViewState中去除,这样可以大大减小页面ViewState的数据大小,使用DataGrid时ViewState数据量太大的根本原因就是列表数据存放在ViewState中。
DataGrid的内部工作流程:在数据绑定初始化的时候,生成了一个叫DataGridTable的控件对象,这个对象是继承System.Web.UI.WebControls.Table控件的。而且这个对象是最先加入(使用Controls.Add()方法)DataGrid中的。而且ViewState中的DataGrid列表数据也是这个控件加入到DataGrid中的。实际上,ViewState中的DataGrid的单元格中的数据实际上是System.Web.UI.WebControls.Table控件的SaveViewState()方法给加进去的。这些数据很多情况下是不需要的。
?
解决方法:在数据绑定的时候,设置DataGrid中DataGridTable控件的EnableViewState属性为False就可以了。
?
首先在页面初始化中的InitializeComponent()方法内加入事件的委托:<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />
private void InitializeComponent()
{
??? this.myDataGrid.ItemDataBound +=
new DataGridItemEventHandler(this.myDataGrid_ItemDataBound);
}
然后在myDataGrid_ItemDataBound方法内加入控制代码:
private void myDataGrid_ItemDataBound(object sender, DataGridItemEventArgs e)
{
??? myDataGrid.Controls[0].EnableViewState = false;
}
使用DataGrid时,把上面的代码加入,将减小使用DataGrid时ViewState的90%的数据量。而且,DataGrid中许多使用ViewState的功能丝毫不少,岂不是两全其美?
?
当然,网页执行第一次时,DataGrid的内容正常显示,而使用了上面的去除ViewState方法后,页面如果回发处理,DataGrid的内容将会消失。我才明白DataGrid内DataGridTable把数据存放在ViewState内的用意。微软的设计是非常严谨的,他们的用意就是当使用Page.IsPostBack属性时,仅访问一次数据库就可以永久保持DataGrid的数据(在不离开此页面的情况下),数据存放的地点就是页面的ViewState中。这样页面回发后,DataGrid就可以从ViewState中重新生成DataGrid的显示内容,无需访问数据库。所以说微软以牺牲客户下载的速度(ViewState数据量)来保证服务器的资源,大家都知道频繁访问数据库对服务器的资源消耗很大。
所以,使用上面减少DataGrid的ViewState数据的法子是可行的,但是必须使所有的页面回发处理都必须进行数据绑定,否则DataGrid无法获得数据库内容,也无法获得ViewState中保存的数据,那么回发后DataGrid将无法显示任何内容。
?
总结:使用上面减少ViewState的办法可以大大加快客户端的下载显示速度,但是频繁的数据库访问将加大服务器的压力;使用ViewState可以减轻服务器的压力,但是又加大了客户端的下载时间,它们是互相矛盾的。所以开发者要根据实际情况选择是否使用DataGrid.Controls[0].EnableViewState=false;的法子,如何选择,大家请自己斟酌。
分享到:
相关推荐
从DATAGRID中导出数据到EXCELL国外代码
JS EasyUI DataGrid动态加载数据
实现了数据的双向绑定,更改DataGrid的数据会更新后台数据,更改后台数据会在DataGrid上实时显示。
通过将DataGrid保存在.xps文件中,实现对DataGrid数据的打印
在DataGrid控件中设置单元格的数据显示格式.
呵呵,datagrid 接收数据常用方法,可供参考。哈哈哈哈哈哈哈
这是一个在VB中使用 数据库绑定控件DataGrid的实例,演示了如何将从数据库中读取出的数据显示到DataGrid控件中。本例子中包括了很多ADO 操作数据库方面的基本操作,是新手学习VB环境下的ado操作的好范例,比如添加、...
在web窗体设计中 利用datagrid显示数据更新数据的一个简单示例。
DataGrid自动增加数据 DataGrid自动增加数据 DataGrid自动增加数据 DataGrid自动增加数据
flex中dataGrid导出数据到excel中,不存在乱码问题
c#实现御览、打印datagrid中的数据
如何优化大数据量加载DataGrid
EasyUI:基本布局&tree菜单数据的绑定&DataGrid数据查询&数据绑定&分页
DataGrid中的数据可以用鼠标拖拽到TreeView中。
把DataGridView导出到Excel文件的示例,己经经过调试,下载即可使用~
System.Windows.Controls.DataGrid DataGrid = dataGrid1; string file = "C:Users\\Administrator\\Desktop\\qb"; Export(DataGrid, file); } public static void Export(System.Windows.Controls.DataGrid...
easyui的datagrid的数据渲染
VB6 设计带记忆的数据录入窗口,这种记忆实际上是将DataGrid临时输入的数据存入到数据库中了,是一个数据库应用范例,本例子中的数据库采用的Access。在本例中,用户临时对任意DataGrid行列操作时输入的内容,临时...
WPF中使用DataGrid完成一个行级数据折叠收缩展开的功能,通过点击行头折叠或者展开明细数据。该能能常见的使用在数据的明细汇总展示上,初始展示汇总数据点击展示某行汇总的结果展示对应的明细信息。
VB利用DataGrid控件辅助录入数据小实例