当前位置: 首页 > 图文教程 > 网络编程 > ASP.NET > ASP.NET 2.0教程:Bind标签和Eval标签

ASP.NET
ASP.NET错误处理:Runtime Error
如何使用ADO.NET Entity Framework从数据库中获取图片
ASP.NET教程:WaitHandle类
ASP.Net中Ado.Net Entity Framework实际项目应用释疑
ASP.NET页面中控制部分元素隐现的方法
asp.net网站开发中使用Sqlite嵌入式数据库
ASP.NET教程:调用WebService的源码
.NET中的垃圾回收
asp.net教程:编译错误同时存在于不同dll中
ASP.NET4.0新改进和新特性
ASP教程:防SQL注入
ASP.NET教程:HttpContext类Current属性
在Win2003 IIS 6.0中安装ASP.net环境
asp.net2.0中App_GlobalResources用途
利用Windows系统服务自动更新网站
无缝的缓存读取:双存储缓存策略
WebServices的性能特别慢是真的吗?
ASP.NET MVC的Web应用程序更直观
PHP和ASP.NET代码哪个运行速度更快?
ASP.NET常用代码

ASP.NET 2.0教程:Bind标签和Eval标签


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 60 ::
收藏到网摘: n/a

在ASP.NET 2.0中新引入的Bind和Eval标签简化了1.1中的DataBinder.Eval()的写法. 多数情况下你不会注意到新增的这两个TAG有什么大的区别, 不过或许你会发现VS编辑器在设计界面下生成的代码默认是使用Bind, 这里主要可能有两个原因:

  1. Eval在后端使用反射来绑定数据, 因此速度比较慢
  2. Eval通常是用于只读的数据展示, Bind则支持与xxxDataSource这类控件的直接集成

也许Bind正是基于这种考虑, (自动绑定Update之类的方法), 类似下面这样的做法将不会像我们所想的那样工作:

 1: Text='<%# Bind("ApplicationName") + "-" + Bind("WorkItemId") %>'

最后显示的结果是Bind(”WorkItemId”)的结果, 之前的结果包括连接字符串全部都被省略掉了. 可以想象由于Bind试图要自动更新回数据库(即便你没有这么做), 如果用于多个字段的绑定其自动更新机制可能会无法判断. 因此这种情况下你就可以使用Eval来代替了. 当然, 如果要追求最好的性能, 就应该使用显式的类型转换, 如下:

 1: Text='<%# ((System.Data.DataRowView)Container.DataItem)["ApplicationName"] 
 2: + "-" + ((System.Data.DataRowView)Container.DataItem)["WorkItemId"] %>'

注:上述例子假设数据源为弱类型的DataSet