河南鄭州企業網站建設網絡公司多爾福科技
服務熱線:0371-60999820
15238075082
C# Eval在asp.net中的用法及作用
Eval( " ")和Bind( " ") 這兩種一個單向綁定,一個雙向綁定,bind是雙向綁定,但需數據源支持
ASP.NET   2.0改善了模板中的數據綁定操作,把v1.x中的數據綁定語法DataBinder.Eval(Container.DataItem,   fieldname)簡化為Eval(fieldname)。Eval方法與DataBinder.Eval一樣可以接受一個可選的格式化字符串參數。縮 短的Eval語法與DataBinder.Eval的不同點在于,Eval會根據最近的容器對象(例如DataListItem)的DataItem屬性 來自動地解析字段,而DataBinder.Eval需要使用參數來指定容器。由于這個原因,Eval只能在數據綁定控件的模板中使用,而不能用于 Page(頁面)層。當然,ASP.NET   2.0頁面中仍然支持DataBinder.Eval,你可以在不支持簡化的Eval語法的環境中使用它。

1.DataBinder.Eval用法
//顯示二位小數
//{0:G}代表顯示True或False
//轉換類型
 ((string)DataBinder.Eval(Container, "DataItem.P_SHIP_TIME_SBM8")).Substring(4,4)

{0:d} 日期只顯示年月日
{0:yyyy-mm-dd} 按格式顯示年月日
{0:c} 貨幣樣式

2.Container.DataItem用法. 
在綁定數據時經常會用到這個句程序:<%# DataBinder.Eval

(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval

(Container,"DataItem.xxxx")%>

還有一種,而且微軟也說這種方法的效率要比以上兩種高。

<%# ((DataRowView)Container.DataItem)["xxxx"]%>

很有用的,這樣可以在前臺頁面做好多事情了。

還要記住要這樣用必須要在前臺頁面導入名稱空間System.Data,否則會生成錯誤信息。

<%@ Import namespace="System.Data" %>

這種用法其實和<%# ((DictionaryEntry)Container.DataItem).Key%>是一個道理。

關鍵是Container這個東西,它的名稱空間是System.ComponentModel。


3.DataBinder.Eval和Container.DataItem的區別
                                       
DataBinder.Eval(Container.DataItem,"Name")和Container.DataItem("Name")有什么區別?
DataBinder是System.Web里面的一個靜態類,它提供了Eval方法用于簡化數據綁定表達式的編寫,但是它使用的方式是通過 Reflection等開銷比較大的方法來達到易用性,因此其性能并不是最好的。而Container則根本不是任何一個靜態的對象或方法,它是 ASP.NET頁面編譯器在數據綁定事件處理程序內部聲明的局部變量,其類型是可以進行數據綁定的控件的數據容器類型(如在Repeater內部的數據綁 定容器叫RepeaterItem),在這些容器類中基本都有DataItem屬性,因此你可以寫Container.DataItem,這個屬性返回的 是你正在被綁定的數據源中的那個數據項。如果你的數據源是DataTable,則這個數據項的類型實際是DataRowView。

數據綁定表達式必須包含在<%#和%>字符之間。格式如下:

<tagprefix:tagname property='<%# data-binding expression %>' runat="server" />

或者如下:

<%# data-binding expression %>

ASP.NET 支持分層數據綁定模型,數據綁定表達式使用 Eval 和 Bind 方法將數據綁定到控件,并將更改提交回數據庫。
Eval 方法是靜態單向(只讀)方法,所以Eval 函數用于單向(只讀)綁定,該方法采用數據字段的值作為參數并將其作為字符串返回。
Bind 方法支持讀/寫功能,所以Bind 函數用于雙向(可更新)綁定。該方法可以檢索數據綁定控件的值并將任何更改提交回數據庫。
XPath 方法支持對XML類型的數據源提供支持。

數據綁定表達式都可以出現在頁面的哪個位置呢?

一,可以將數據綁定表達式包含在服務器控件或者普通的html元素的開始標記中屬性名/屬性值對的值側。例如:

<asp:TextBox ID="TextBox1" runat="server" Text='<%#數據綁定表達式%>' ></asp:TextBox><br />
注意條款:此時數據的綁頂表達式可以是一個變量,也可以是一個帶返回值的C#或者VB.NET方法,還可以是某個控件的某個屬性的值,也可以是C#或者VB.NET對象的某個字段或者屬性的值等等。當然也可以直接就是一個字符串,例如"hello"。
如果此時的數據綁定表達式是Eval("數據庫中某個表的某個字段")等,那么必須把TextBox1放在某個循環顯示的控件的模板中才正確,否則會提 示:Eval()、XPath() 和 Bind() 這類數據綁定方法只能在數據綁定控件的上下文中使用。其實就是想讓你把TextBox1放在像Repeater,DataList,GridView這樣 的控件的模板中。

二,數據綁定綁定表達式包含在在頁面中的任何位置。
同樣遵循"一"的注意條款。
如果此時的數據綁定表達式是Eval("數據庫中某個表的某個字段")等,那么必須把 <%#Eval("數據綁定表達式1")%>   <%#Eval("數據綁定表達式2")%>  放在像Repeater,DataList,GridView這樣的控件的模板中。

三,可以將數據綁定表達式包含在Javascript代碼中,從而實現在Javascript中調用C#或者VB.NET的方法。
數據綁定表達式都可以是什么類型呢?
1,可以是一個變量
例如:<asp:Label ID="Label1" runat="server" Text="<%#變量名%>"></asp:Label>
2,可以是服務器控件的屬性值
例如: <asp:Label ID="Label1" runat="server" Text="<%#TextBox2.Text %>"></asp:Label>
3,可以是一個數組等集合對象
例如把一個數組綁定到列表控件,例如ListBox等,或者Repeater,DataList,GridView這樣的控件等,此時只需要把屬性DataSource='<%# 數組名%>' 。
4,可以是一個表達式
例如:Person是一個對象,Name和City是它的2個屬性,則數據綁定表達式可以這樣寫:
<%#(Person.Name + " " + Person.City)%>。
5,可以是一個方法
例如:<%#GetUserName()%>。GetUserName()是一個已經定義的C#方法,一般要求有返回值。
6,可以是用Eval,DateBind.Eval取得的數據表的字段,這個是最常見的了,不再舉例。

注意:如果數據綁定表達式作為屬性的值,只要數據綁定表達式中沒有出現雙引號,那么<%#數據綁定表達式%>的最外層用雙引號或者單引號都可以。如果數據綁定表達式中出現雙引號,則<%#數據綁定表達式%>的最外層最好要用單引號。

與數據庫有關的數據綁定表達式的常用方法?

1,<%#DataBind.Eval(Container.DataItem,"字段名")%>
      <%#DataBind.Eval(Container.DataItem,"字段名","{0:c}") %>
     還有2種不常用的:
      <%# DataBinder.Eval(Container,"DataItem.字段名")%> 
      <%# DataBinder.Eval(Container,"DataItem.字段名",{0:c})%> 
      Container.DataItem相當于數據庫中某個表中的一行記錄,而一行可以有很多列。
      最后一個參數和 String.Format的形式一樣。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點后三為,一次類推。

         使用三目運算符?:的例子:
 <%# DataBinder.Eval(Container.DataItem, "字段 名").ToString().Trim().Length>16?DataBinder.Eval(Container.DataItem, "字段 名").ToString().Trim().Substring(0,16):DataBinder.Eval(Container.DataItem, "字段名").ToString().Trim() %>

2,<%#Eval("字段名")%>
     <%#Eval("字段名","{0:c}")%>
     .NET 2.0新出現的一個方法。和DataBind.Eval()等價。
     最后一個參數和 String.Format的形式一樣。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點后三位,一次類推。

     使用三目運算符的例子:
<%#(Eval("性別")).ToString() =="True"?"男":"女"%>  
 性別字段類型為:是/否(Access),bit(sql server)
      使用方法調用的例子:
  <%# GetUserPhoto(Eval("PhotoPath")) %>    
     GetUserPhoto()的定義:


string GetUserPhoto(object photoPath)
{
  if (photoPath == DBNull.Value)<%#((DataRowView)Container.DataItem)["字段名"] %>

  {
      return "<img src='Images/none.gif'>";
  }
  else
  {
    return "<img src='Upload/" +photoPath.ToString() + "'>";
  }
}
 3, <%#((DataRowView)Container.DataItem)["字段名"] %>
      <%# string.Format("{0:c}", ((DataRowView)Container.DataItem)["字段名"])%>
          用String.Format方法設定字段的顯示樣式。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點后三為,一次類推。
       
       類型轉換例子:<%# (int)((DataRowView)Container.DataItem)["字段名1"]*(int) ((DataRowView)Container.DataItem)["字段名2"]%>    意思是2個字段相乘。
     
上面三種綁定方法的效率:Eval方法執行時候會調用DataBinder.Eval方法,DataBinder.Eval方法在運行時使用反射執行后期 綁定計算,會導致性能明顯下降。所以會導致性能明顯下降。所以三者中<%#((DataRowView)Container.DataItem) ["字段名"] %>的性能最好。
上一篇: 淺談SQL Server 的命名規則 下一篇: Eval綁定多表查詢后的數據
網站首頁 | 關于我們 | 版權所有 | 網站地圖 | 服務項目 | 網站建設 | 網站優化 | 軟件開發 | 經典案例 | 常見問題 | 聯系我們
版權所有:河南多爾福電子科技有限公司 豫ICP17014991號-2 技術支持:多爾福科技
地址:河南省鄭州市鄭東新區東風南路萬通街英地金臺府邸4號樓2單元1204室。 手機:15238075082 Email:[email protected]
大乐透胆拖中奖规则图