数据绑定表达式必须包含在<%#%>字符之间。格式如下:

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

ASP.NET 支持分层数据绑定模型,数据绑定表达式使用 Eval Bind 方法将数据绑定到控件,并将更改提交回数据库。

Eval 方法是静态单向(只读)方法,所以Eval 函数用于单向(只读)绑定,该方法采用数据字段的值作为参数并将其作为字符串返回。

Bind 方法支持读/写功能,所以Bind 函数用于双向(可更新)绑定。该方法可以检索数据绑定控件的值并将任何更改提交回数据库。

数据绑定表达式都可以出现在页面的一下个位置:

一,可以将数据绑定表达式包含在服务器控件或者普通的html元素的开始标记中属性名/属性值对的值侧。

例如:

<asp:TextBox runat="server" Text='<%#数据绑定表达式 %>'></asp:TextBox>

注意条款:此时数据的绑顶表达式可以是一个变量,也可以是一个带返回值的C#或者VB.NET方法,还可以是某个控件的某个属性的值,也可以是C#或者VB.NET对象的某个字段或者属性的值等等。当然也可以直接就是一个字符串,例如"hello"

如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段"),那么必须把TextBox1放在某个循环显示的控件的模板中才正确,否则会提示:Eval()XPath() Bind() 这类数据绑定方法只能在数据绑定控件的上下文中使用

。其实就是想让你把TextBox1放在像Repeater,DataList,GridView这样的控件的模板中。

二,数据绑定绑定表达式包含在在页面中的任何位置

例如:

<div>
     <%#数据绑定表达式 %>
     <%#数据绑定表达式 %>
</div>

同样遵循""的注意条款。

如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段"),那么必须把 <%#Eval(

数据绑定表达式1")%>   <%#Eval("数据绑定表达式2")%>  放在像Repeater,DataList,GridVie

这样的控件的模板中。

三,可以将数据绑定表达式包含在Javascript代码中,从而实现在Javascript中调用C#VB.NET的方法。

例如:

Deafult2.aspx:

<script language="javascript" type="text/javascript">
      function GetStr() {
          var a;
          a = '';
          a = '<%#CSharpToJavaScript() %>>';
          alert(a);
      }
</script>

Default2.aspx.cs:

public string CSharpToJavaScript()
{
    ...
}

数据绑定表达式都可以是一下类型:
1,可以是一个变量
例如:<asp:LabelID="Label1" runat="server" Text="<%#变量名%>"></asp:Label>
2,可以是服务器控件的属性值
例如: <asp:LabelID="Label1" runat="server" Text="<%#TextBox2.Text%>"></asp:Label>
3,可以是一个数组等集合对象
例如把一个数组绑定到列表控件,例如ListBox等,或者Repeater,DataList,GridView这样的控件等,此时只需要把属性DataSource='<%# 数组名%>'
4,可以是一个表达式
例如:Person是一个对象,NameCity是它的2个属性,则数据绑定表达式可以这样写:
<%#(Person.Name + " " + Person.City)%>
5,可以是一个方法
例如:<%#GetUserName()%>GetUserName()是一个已经定义的C#方法,一般要求有返回值。
6,可以是用Eval,DateBinder.Eval取得的数据表的字段


注意:如果数据绑定表达式作为属性的值,只要数据绑定表达式中没有出现双引号,那么<%#数据绑定表达式%>的最外层用双引号或者单引号都可以。如果数据绑定表达式中出现双引号,则<%#数据绑定表达式%>的最外层最好要用单引号。

与数据库有关而且绑定到DataView,DataTable,DataSet 等数据源的数据绑定表达式有:

1<%#DataBinder.Eval(Container.DataItem,"字段名")%>

<%#DataBinder.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).Eval(

ConTainer.DataItem,”字段名”).ToString.Trim()%>

2<%#Eval("字段名")%>

<%#Eval("字段名","{0:c}")%>

.NET 2.0新出现的一个方法。和DataBinder.Eval()等价。

最后一个参数和String.Format的形式一样。例如c代表货币,p代表百分号,d代表

日期格式显示,f代表浮点数现实,f3代表小数点后三位,一次类推。

<%#string.Format("{0:yyyy-MM-dd dddd}",Eval("date")) %>
<%#DataBinder.Eval(Container.DataItem,"date","{0:yyyy-MM-dd}") %>

使用三目运算符的例子:

<%#(Eval("性别")).ToString()=="True"?"男":"女"%>

性别字段类型为:是/(Access)bit(sql server)

使用方法调用的例子:

<%# GetUserPhoto(Eval("PhotoPath")) %>

GetUserPhoto()的定义:

private string GetUserPhoto(object photoPath)
{
    if (photoPath==DBNull.Value)
    {
        return "<img src='Images/none.gif'/>";
    }
    else
    {
        return "<img src='Images/"+photoPath+"'/>";
    }
}