欢迎光临
我们一直在努力

去掉DataGrid的ViewState中的无用数据-ASP教程,数据库相关

建站超值云服务器,限时71元/月

在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()方法内加入事件的委托:

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;的法子,如何选择,大家请自己斟酌。

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 去掉DataGrid的ViewState中的无用数据-ASP教程,数据库相关
分享到: 更多 (0)

相关推荐

  • 暂无文章