首先,eval与bind是两个方法,都可以实现前台数据绑定
Bind方法(双向数据绑定)即能把数据绑定到控件,又能把数据变更提交到数据库。
Eval方法(单向数据绑定)它实现了数据读取的自动化,并能对绑定字段进行格式化显示,但是没有实现数据写入自动化。
比如,当有GridView、DetailsView控件的时候,Bind方法可以使控件从模板中的子控件中提取值,并将这些值传递给数据源控件。然后数据源控件将执行适当的数据库命令。所以在数据绑定控件的EditItemTemplate或InsertItemTemplate中要使用Bind函数。
其次,在进行数据绑定的时候,可以用DataBinder.Eval或者直接用Container.DataItem
DataBinder.Eval(Container.DataItem, "字段")
DataBinder.Eval(Container, "DataItem.字段")
/********************************************/
((对象类型)Container.DataItem).属性
如果是GridView,Repeat,DataList等
就是((DataRowView)Container.DataItem).Row["字段名"]
如果是SqlDataReader
就是((DbDataRecord)Container.DataItem)["字段名"]
下面就来看看这两种数据绑定的区别
Eval是通过反射的方式来获取值,而Container则是ASP.NET页面编译器在数据绑定事件处理程序内部声明的局部变量,里面存有值。
这样看来,用Container效率应该比较高,但是有一网友做了一组这样的测试
1.<@% DataBinder.Eval(Container.DataItem, "ColumnName") %>
2.<@% DataBinder.Eval(Container.DataItem, "ColumnName", null) %>
3.<@% DataBinder.Eval(Container, "DataItem.ColumnName", null) %>
4.<@% ((DataRowView)Container.DataItem)["ColumnName"] %>
5.<@% ((DataRowView)Container.DataItem).Row["ColumnName"] %>
来看哪个效率高,得出的结论是前三种由于用了反射,所以效率不高,但是第四种在某些情况下效率更低,第五种是一种比较合适的写法
参考的文章:
数据绑定以及Container.DataItem的具体分析
http://space.itpub.net/12639172/viewspace-481782
Eval 和 Bind 方法的区别
http://www.cnblogs.com/dupeng0811/archive/2009/03/23/1419600.html
数据绑定以及Container.DataItem几种方式与用法分析
http://www.diybl.com/course/4_webprogram/asp.net/netjs/200847/108607.html
请问Bind ,Eval有说明区别?大家来讨论讨论
http://faq.csdn.net/read/216609.html
分享到:
相关推荐
<%# DataBinder.Eval(Container.DataItem, "ShipDate", "{0:yyyy-MM-dd}") %> ``` - **数值格式化**: ```html <%# DataBinder.Eval(Container.DataItem, "Price", "{0:#,##0.00}") %> ``` 通过以上介绍,...
7. Eval()方法可以显示日期,只显示年月日,例如:<%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:yyyy-M-d}")%> 8. Eval()方法可以显示货币样式,例如:<%#Container.DataItem("price","{0:¥#,#...
- 格式化为年-月-日的日期:`<%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:yyyy-M-d}")%>` - 科学计数法:`<%# DataBinder.Eval(Container.DataItem, "DoubleValue", "{0:e}")%>` - 固定小数点...
DataBinder.Eval方法的基本语法是`<%# DataBinder.Eval(Container.DataItem, "ColumnName") %>`, 其中`ColumnName`是你想要绑定的数据源字段名。例如,`<%# Bind("Subject") %>`将绑定数据源中的"Subject"字段。 2....
相比之下,`DataBinder.Eval`是更通用的方法,它需要显式提供当前数据容器的引用,即`Container.DataItem`,以及需要绑定的字段名,如`DataBinder.Eval(Container.DataItem, "FieldName")`。这种方法允许在页面级别...
< %# DataBinder.Eval(Container.DataItem, "数据字段1")%>’ & name=’<% # DataBinder.Eval(Container.DataItem, "数据字段2")%>’ /> 7.表格点击改变颜色 if (e.Item.ItemType == ListItemType.Item ||e....
DataBinder.Eval(Container.DataItem, "Title").ToString().Substring(0, 20) + "…" : DataBinder.Eval(Container.DataItem, "Title")%> ``` #### 11. GridView一般换行与强制换行 在某些情况下,你可能...
id='<%# DataBinder.Eval(Container.DataItem, "数据字段1")%>' & name='<%# DataBinder.Eval(Container.DataItem, "数据字段2")%>' /> 7.表格点击改变颜色 if (e.Item.ItemType == ListItemType.Item ||e.Item....
<%# DataBinder.Eval(Container.DataItem, "Text").ToString().Replace("\n", " ") %> ``` #### 十三、GridView显示隐藏某一列 **1. 实现原理:** 通过设置`Visible`属性来控制某一列的显示或隐藏。 **...
- 示例代码:在GridView的模板字段中添加 `DropDownList` 控件,并为其绑定数据源。 ```csharp 选项1 选项2 ``` #### 5. GridView和CheckBox结合 **知识点**:实现GridView中的复选框...