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

ASP.NET
aspnet_regsql不能在sql2005下使用的解决
.NET发送邮件
让.Net验证控件与自定义验证合作无间
给.Net程序员和WEB程序员建议:.Net篇
给.Net程序员和WEB程序员建议:WEB篇
Server Application Unavailable错误解决方法
ASP.NET AJAX:UpdatePanel控件
ASP.NET教程:Ref和Out关键字异同
组件Newtonsoft.Json实现object2json转换
ASP.NET教程:Control基类清理页面状态
ASP.NET入门教程:认识ASP.NET
ASP.NET入门教程:ASP.NET和ASP区别
ASP.NET入门教程:简单的ASP.NET页面
ASP.NET入门教程:服务器控件
ASP.NET入门教程:事件句柄
ASP.NET入门教程:Web表单
ASP.NET入门教程:Web表单维持对象的ViewState
ASP.NET入门教程:TextBox控件
ASP.NET入门教程:Button控件
ASP.NET入门教程:数据绑定

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


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