NET中前台数据绑定的方法
数据绑定表达式必须包含在<%#和%>字符之间。格式如下:
<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是一个对象,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代表小数点后三位,一次类推。
<%#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+"'/>"; } }
转载于:https://blog.51cto.com/hddev/1253873
上一篇: springboot的错误页面配置
下一篇: 盘点红糖是什么做的,让大家吃红糖吃得放心
推荐阅读
-
Mysql5.7中使用group concat函数数据被截断的问题完美解决方法
-
在oracle 数据库查询的select 查询字段中关联其他表的方法
-
asp.net中调用oracle存储过程的方法
-
MSSQL中删除用户时数据库主体在该数据库存中拥有架构 无法删除的解决方法
-
C#实现将数据导出到word或者Excel中的方法
-
将PHP程序中返回的JSON格式数据用gzip压缩输出的方法
-
asp.net实现导出DataTable数据到Word或者Excel的方法
-
ASP.NET在MVC控制器中获取Form表单值的方法
-
ASP.NET MVC4中使用Html.DropDownListFor的方法示例
-
php从数据库中获取数据用ajax传送到前台的方法