ASP.NET 声明性数据绑定语法使用 <%# %> 表示法。
<asp:LinkButton Text='<%# DataBinder.Eval(Container.DataItem, “qdbm”) %>’ Runat=”server”/>
以下内容来自于:
http://mirwang.yculblog.com/post-188640.html
不过看来也是引用他人的,例子连接失效。
数据绑定服务器控件
数据绑定概述和语法
绑定到简单属性
绑定到集合和列表
绑定表达式或方法
DataBinder.Eval()
本节小结
——————————————————————————–
数据绑定概述和语法
ASP.NET 引入了新的声明性数据绑定语法。这种非常灵活的语法允许开发人员不仅可以绑定到数据源,而且可以绑定到简单属性、集合、表达式甚至是从方法调用返回的结果。下表显示了新语法的一些示例。
简单属性 Customer: <%# custID %>
集合 Orders: <asp:ListBox id=”List1″ datasource='<%# myArray %>’ runat=”server”>
表达式 Contact: <%# ( customer.First Name + ” ” + customer.LastName ) %>
方法结果 Outstanding Balance: <%# GetBalance(custID) %>
尽管该语法看起来与 ASP 的 Response.Write 快捷方式 <%= %> 相似,但其行为完全不同。ASP Response.Write 快捷方式语法在处理页时计算,而 ASP.NET 数据绑定语法仅在调用 DataBind 方法时计算。
DataBind 是页和所有服务器控件的方法。当在父控件上调用 DataBind 时,它级联到该控件的所有子控件。例如,DataList1.DataBind() 将因此对 DataList 模板中的每一控件调用 DataBind 方法。在页上调用 DataBind — Page.DataBind() 或只是 DataBind() — 会导致计算页上的所有数据绑定表达式。通常从 Page_Load 事件调用 DataBind,如下例所示。
protected void Page_Load(Object Src, EventArgs E) {
DataBind();
}
Protected Sub Page_Load(Src As Object, E As EventArgs)
DataBind()
End Sub
protected function Page_Load(Src:Object, E:EventArgs) : void {
DataBind();
}
C# VB JScript
如果绑定表达式在运行时计算为预期的数据类型,则可以在 .aspx 页的声明节中的几乎任何位置使用绑定表达式。上面的简单属性、表达式和方法示例在计算时向用户显示文本。这些情况下,数据绑定表达式必须计算为 String 类型的值。在集合示例中,数据绑定表达式计算为 ListBox 的 DataSource 属性的有效类型值。您可能会发现有必要转换绑定表达式中的类型值以产生所需的结果。例如,如果 count 是整数:
Number of Records: <%# count.ToString() %>
绑定到简单属性
ASP.NET 数据绑定语法支持绑定到公共变量、页的属性和页上其他控件的属性。
下面的示例说明如何绑定到公共变量和页上的简单属性。注意这些值在 DataBind() 调用前初始化。
VB DataBind1.aspx
[运行示例] | [查看源代码]
下面的示例说明如何绑定到另一控件的属性。
VB DataBind2.aspx
[运行示例] | [查看源代码]
绑定到集合和列表
像 DataGrid、ListBox 和 HTMLSelect 这样的列表服务器控件将集合用作数据源。下面的示例说明如何绑定到通常的公共语言运行库集合类型。这些控件只能绑定到支持 IEnumerable、ICollection 或 IListSource 接口的集合。最常见的是绑定到 ArrayList、Hashtable、DataView 和 DataReader。
下面的示例说明如何绑定到 ArrayList。
VB DataBind3.aspx
[运行示例] | [查看源代码]
下面的示例说明如何绑定到 DataView。注意 DataView 类在 System.Data 命名空间中定义。
VB DataBind4.aspx
[运行示例] | [查看源代码]
下面的示例说明如何绑定到 Hashtable。
VB DataBind5.aspx
[运行示例] | [查看源代码]
绑定表达式或方法
通常需要在绑定到页或控件之前操作数据。下面的示例说明如何绑定到表达式和方法的返回值。
VB DataBind6.aspx
[运行示例] | [查看源代码]
DataBinder.Eval
ASP.NET 框架提供了一种静态方法,计算后期绑定的数据绑定表达式并且可选择将结果格式化为字符串。DataBinder.Eval 很方便,因为它消除了开发人员为强迫将值转换为所需的数据类型而必须做的许多显式转换。这在数据绑定模板列表内的控件时尤其有用,因为通常数据行和数据字段的类型都必须转换。
请看下面的示例,本例中整数将显示为货币字符串。使用标准的 ASP.NET 数据绑定语法,必须首先转换数据行的类型以便检索数据字段 IntegerValue。下一步,将此作为参数传递给 String.Format 方法。
<%# String.Format(“{0:c}”, ((DataRowView)Container.DataItem)[“IntegerValue”]) %>
<%# String.Format(“{0:c}”, (CType(Container.DataItem, DataRowView)(“IntegerValue”))) %>
<%# String.Format(“{0:c}”, (DataRowView(Container.DataItem))[“IntegerValue”]) %>
C# VB JScript
该语法可能比较复杂,难以记忆。相反,DataBinder.Eval 只是一个具有三个参数的方法:数据项的命名容器、数据字段名和格式字符串。在像 DataList、DataGrid 或 Repeater 这样的模板列表中,命名容器始终是 Container.DataItem。Page 是另一个可与 DataBinder.Eval 一起使用的命名容器。
<%# DataBinder.Eval(Container.DataItem, “IntegerValue”, “{0:c}”) %>
<%# DataBinder.Eval(Container.DataItem, “IntegerValue”, “{0:c}”) %>
<%# DataBinder.Eval(Container.DataItem, “IntegerValue”, “{0:c}”) %>
C# VB JScript
格式字符串参数是可选的。如果省略它,则 DataBinder.Eval 返回对象类型的值,如下例所示。
<%# (bool)DataBinder.Eval(Container.DataItem, “BoolValue”) %>
<%# CType(DataBinder.Eval(Container.DataItem, “BoolValue”), Boolean) %>
<%# Boolean(DataBinder.Eval(Container.DataItem, “BoolValue”)) %>
C# VB JScript
DataBinder.Eval 会对标准数据绑定语法带来很明显的性能损失,因为它使用后期绑定反射,注意这一点很重要。使用 DataBinder.Eval 时需谨慎,尤其是在不需要字符串格式化时。
VB DataBind7.aspx
[运行示例] | [查看源代码]
本节小结
ASP.NET 声明性数据绑定语法使用 <%# %> 表示法。
可以绑定到数据源、页或其他控件的属性、集合、表达式以及从方法调用返回的结果。
列表控件可以绑定到支持 ICollection、IEnumerable 或 IListSource 接口的集合,如 ArrayList、Hashtable、DataView 和 DataReader。
DataBinder.Eval 是用于晚期绑定的静态方法。它的语法可能比标准数据绑定语法简单,但性能较低。