<%# Container.DataItemIndex + 1%> //實現自動編號
<%# DataBinder.Eval(Container.DataItem, "[n]") %>
一般使用的方法(這三個性能最好)
<%# DataBinder.Eval(Container.DataItem, "ColumnName") %>
<%# DataBinder.Eval(Container.DataItem, "ColumnName", null) %>
<%# DataBinder.Eval(Container, "DataItem.ColumnName", null) %>
其餘用法
<%# ((DataRowView)Container.DataItem)["ColumnName"] %>
<%# ((DataRowView)Container.DataItem).Row["ColumnName"] %>
<%# ((DataRowView)Container.DataItem)["adtitle"] %>
<%# ((DataRowView)Container.DataItem)[n] %>
<%# ((DbDataRecord)Container.DataItem)[0] %>
<%# (((自定義類型)Container.DataItem)).屬性.ToString() %>//若是屬性爲字符串類型就不用ToString()了
DataBinder.Eval用法範例
<%# DataBinder.Eval(Container.DataItem, "IntegerValue", "{0:c}") %>
格式化字符串參數是可選的。若是忽略參數,DataBinder.Eval 返回對象類型的值,
//顯示二位小數
<%# DataBinder.Eval(Container.DataItem, "UnitPrice", "${0:F2}") %>
//{0:G}表明顯示True或False
<ItemTemplate>
<asp:Image Width="12" Height="12" Border="0" runat="server"
AlternateText='<%# DataBinder.Eval(Container.DataItem, "Discontinued", "{0:G}") %>'
ImageUrl='<%# DataBinder.Eval(Container.DataItem, "Discontinued", "~/images/{0:G}.gif") %>' />
</ItemTemplate>
//轉換類型
((string)DataBinder.Eval(Container, "DataItem.P_SHIP_TIME_SBM8")).Substring(4,4)
{0:d} 日期只顯示年月日
{0:yyyy-mm-dd} 按格式顯示年月日
{0:c} 貨幣樣式
<%#Container.DataItem("price","{0:¥#,##0.00}")%>
<%# DataBinder.Eval(Container.DataItem,"Company_Ureg_Date","{0:yyyy-M-d}")%>
Specifier Type Format Output (Passed Double 1.42) Output (Passed Int -12400)
c Currency {0:c} $1.42 -$12,400
d Decimal {0:d} System.FormatException -12400
e Scientific {0:e} 1.420000e+000 -1.240000e+004
f Fixed point {0:f} 1.42 -12400.00
g General {0:g} 1.42 -12400
n Number with commas for thousands {0:n} 1.42 -12,400
r Round trippable {0:r} 1.42 System.FormatException
x Hexadecimal {0:x4} System.FormatException cf90
{0:d} 日期只顯示年月日
{0:yyyy-mm-dd} 按格式顯示年月日
樣式取決於 Web.config 中的設置
{0:c} 或 {0:£0,000.00} 貨幣樣式 標準英國貨幣樣式
<system.web>
<globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="en-US" uiCulture="en-US" />
</system.web>
顯示爲 £3,000.10
{0:c} 或 string.Format("{0:C}", price); 中國貨幣樣式
<system.web>
<globalization requestEncoding="utf-8" responseEncoding="utf-8" culture="zh-cn" uiCulture="zh-cn" />
</system.web>
顯示爲 ¥3,000.10
{0:c} 或 string.Format("{0:C}", price); 美國貨幣樣式
<system.web>
<globalization requestEncoding="utf-8" responseEncoding="utf-8" />
</system.web>
顯示爲 $3,000.10web
1,express
<asp:HyperLink runat="server" ID="hlUserName" Text='<%#DataBinder.Eval(Container.DataItem,"UserName") %>' NavigateUrl='<%# string.Format("UserView.aspx?uId={0}",Eval("UserId")) %>' />函數
2,能夠調用cs 中的內部函數和自定義函數:post
(1):性能
<HyerLink runat="server" ID="hlUserName" Text='<%# DateTime.Now.ToString()%>' />ui
(2):this
cs 中:spa
protected string test(string s)orm
{return s.ToUpper();}server
aspx中:
<HyperLink runat="server" ID="hlUserName" Text='<%# test("aaa")%>' />
3,不放在控件中,直接調用函數
<%= DateTime.Now.ToLongDateString()%>
格式化日期:
<%# Eval("finishtime","{0:yyyy-MM-dd}") %>
在綁定數據時常常會用到這個句程序:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%> 微軟這種方法的效率更高,但我不經常使用,我習慣了上一種。 <%# ((DataRowView)Container.DataItem)["xxxx"]%> 用這種方法首先要在前臺頁面導入名稱空間System.Data,不然會生成錯誤信息。 <%@ Import namespace="System.Data" %> DataBinder.Eval()能夠梆定方法,Text='<%# PBnumber(DataBinder.Eval(Container.DataItem,"photoBookID")) %>後臺代碼: string str = "[ " + Convert.ToString(PBc.GetInPbkPnum((int)PBid)) + " ] 張"; return str; DataBinder.Eval還能夠判斷選擇,如以性別爲例: <asp:TemplateColumn HeaderText="性別"> cs裏定義DGFormatSex方法
DataBinder.Eval用法範例 本文假設你已經瞭解ASP.NET 1.1的數據綁定(特別是Container這個局部變量)的機制,這裏主要分析ASP 2.0數據綁定作了那些改進。
ASP.NET 1.1簡化爲:(去掉了類型指定, Eval經過反射實現,本文再也不闡述)
ASP.NET 2.0又簡化爲,去掉了Container局部變量:
那麼,Page.Eval()又是如何知道"ProductName"是那個數據的屬性呢,即Container.DataItem真的消失了嗎? Eval()是Page的父類TemplateControl的方法 TemplateControl.Eval()能夠自動計算出Container, 機制就是從一個dataBindingContext:Stack堆棧來獲取。 1. 創建DataItem Container 棧: 在Control.DataBind()中,創建,這樣能夠保證子控件的DataItem Container始終在棧頂。
2. 獲取DataItem Container
3. TemplateControl.Eval()
結論: 從上面看出Page.Eval()在計算的時候仍是引用了Container.DataItem,只不過這個DataItem經過DataItem Container堆棧自動計算出來的。我認爲Page.Eval()看似把問題簡化了,其實把問題搞得更加神祕。
|