数据绑定表达式必须包含在<%#和%>字符之间。格式如下:
1
|
<
tagprefix:tagname
property='<%#data-binding expression%>' runat="server">
|
ASP.NET 支持分层数据绑定模型,数据绑定表达式使用 Eval 和 Bind 方法将数据绑定到控件,并将更改提交回数据库。
Eval 方法是静态单向(只读)方法,所以Eval 函数用于单向(只读)绑定,该方法采用数据字段的值作为参数并将其作为字符串返回。
Bind 方法支持读/写功能,所以Bind 函数用于双向(可更新)绑定。该方法可以检索数据绑定控件的值并将任何更改提交回数据库。
数据绑定表达式都可以出现在页面的一下个位置:
一,可以将数据绑定表达式包含在服务器控件或者普通的html元素的开始标记中属性名/属性值对的值侧。
例如:
1
|
<asp:TextBox runat=
"server"
Text=
'<%#数据绑定表达式 %>'
></asp:TextBox>
|
注意条款:此时数据的绑顶表达式可以是一个变量,也可以是一个带返回值的C#或者VB.NET方法,还可以是某个控件的某个属性的值,也可以是C#或者VB.NET对象的某个字段或者属性的值等等。当然也可以直接就是一个字符串,例如"hello"。
如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段")等,那么必须把TextBox1放在某个循环显示的控件的模板中才正确,否则会提示:Eval()、XPath() 和 Bind() 这类数据绑定方法只能在数据绑定控件的上下文中使用
。其实就是想让你把TextBox1放在像Repeater,DataList,GridView这样的控件的模板中。
二,数据绑定绑定表达式包含在在页面中的任何位置。
例如:
1
2
3
4
|
<
div
>
<%#数据绑定表达式 %>
<%#数据绑定表达式 %>
</
div
>
|
同样遵循"一"的注意条款。
如果此时的数据绑定表达式是Eval("数据库中某个表的某个字段")等,那么必须把 <%#Eval(
数据绑定表达式1")%> <%#Eval("数据绑定表达式2")%> 放在像Repeater,DataList,GridVie
这样的控件的模板中。
三,可以将数据绑定表达式包含在Javascript代码中,从而实现在Javascript中调用C#或VB.NET的方法。
例如:
Deafult2.aspx:
1
2
3
4
5
6
7
8
|
<script language=
"javascript"
type=
"text/javascript"
>
function
GetStr() {
var
a;
a =
''
;
a =
'<%#CSharpToJavaScript() %>>'
;
alert(a);
}
</script>
|
Default2.aspx.cs:
1
2
3
4
|
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是一个对象,Name和City是它的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代表小数点后三位,一次类推。
1
2
|
<%#
string
.Format(
"{0:yyyy-MM-dd dddd}"
,Eval(
"date"
)) %>
<%#DataBinder.Eval(Container.DataItem,
"date"
,
"{0:yyyy-MM-dd}"
) %>
|
1
|
<%#(Eval(
"性别"
)).ToString()==
"True"
?
"男"
:
"女"
%>
|
性别字段类型为:是/否(Access),bit(sql server)
使用方法调用的例子:
1
|
<%# GetUserPhoto(Eval(
"PhotoPath"
)) %>
|
GetUserPhoto()的定义:
1
2
3
4
5
6
7
8
9
10
11
|
private
string
GetUserPhoto(
object
photoPath)
{
if
(photoPath==DBNull.Value)
{
return
"<img src='Images/none.gif'/>"
;
}
else
{
return
"<img src='Images/"
+photoPath+
"'/>"
;
}
}
|