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

ASP.NET
asp.net Linq TO Sql 分页方法
asp.net 用XML生成放便扩展的自定义树
asp.ent下合并两个结构相同的DataTable
asp.net 遍历repeater中的控件的几种方式
asp.net 处理原文件中过长的viewstate代码
asp.net下遍历页面中所有的指定控件的代码
获取创建Membership的数据库创建脚本
asp.net AJAX注册类
asp.net 处理F5刷新页面重复提交页面的一个思路
ASP.NET 缓存分析和实践浅析提高运行效率
asp.net 读取并显示excel数据的实现代码
ASP.NET中常用的用来输出JS脚本的类
ASP.NET中内嵌页面代码的一个问题
asp.net(C#)操作excel(上路篇)
一个基于Asp.Net MVC的权限方案
ASP.NET实例教程:51job网站地区选择功能
ASP.NET教程:友好的Html和JS适合SEO
ASP.NET教程:使用.ashx文件去除重复内容
ASP.NET做SEO:制作架构清晰和更新及时的网站地图
ASP.NET优化:Sql注入和Html注入的黑帽SEO

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


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-28   浏览: 56 ::
收藏到网摘: 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