首先,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