ASP.NET中的Eval与DataBinder.Eval,方法

1.bind是一种双向数据绑定,有数据源时才会有改变.

2..net1.x版本中有DataBinder(Container.DataItem,"数据项") 单向数据绑定

.net2.x版本中简化为Eval("数据项");

缩写的Eval()与DataBinder()的区别是:

Eval会根据最近的容器对象(例如DataListItem)的DataItem属性来自动地解析字段,

而DataBinder.Eval需要使用参数来指定容器。由于这个原因,Eval只能在数据绑定控件的模板中使用,而不能用于Page(页面)层.

例子:

<asp:DataList DataList1 " RepeatColumns= "5 " Width= "600 " runat= "server " DataSourceObjectDataSource1 ">

  <ItemTemplate>

  <asp:HyperLink HyperLink1 " runat= "server " NavigateUrl= '<%# Eval( "PhotoID ", "PhotoFormViewPlain.aspx?) %> '>

  <asp:Image Image1 " Runat= "server " ImageUrl='<%# Eval( "FileName ", "images/thumbs/{0} ") %> '/></asp:HyperLink>

  <asp:Label CaptionLabel " runat= "server " Text= '<%# Eval( "Caption ") %> ' />

 </ItemTemplate>

</asp:DataList><br />

<asp:ObjectDataSource ObjectDataSource1 " runat= "server " TypeName= "DataComponentTableAdapters.PhotosTableAdapter

" SelectMethod= "GetPhotosForAlbum ">

数据绑定也可以作为控件的主题定义(theme definition)的一部分,这样我们就可以通过改变主题来随意地改变模板化控件的布局和外观。但是Theme(主题)模板中只能使用Eval(或者 后面讨论的Bind)。绑定到任意的用户代码是被禁止的。

1.DataBinder.Eval用法

//显示二位小数

<%# DataBinder.Eval(Container.DataItem, "UnitPrice", "${0:F2}") %>

//{0:G}代表显示True或False

  1. <ItemTemplate>
  2. <asp:Image Width="12" Height="12" runat="server"
  3. AlternateText='<%# DataBinder.Eval(Container.DataItem,
  4. "Discontinued", "{0:G}") %>'
  5. ImageUrl='<%# DataBinder.Eval(Container.DataItem,
  6. "Discontinued", "~/images/{0:G}.gif") %>' />
  7. </ItemTemplate>

//转换类型

((string)DataBinder.Eval(Container, "DataItem.P_SHIP_TIME_SBM8")).Substring(4,4)

{0:d} 日期只显示年月日

{0:yyyy-mm-dd} 按格式显示年月日

{0:c} 货币样式

2.Container.DataItem用法.

在绑定数据时经常会用到这个句程序:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%>

还有一种,而且微软也说这种方法的效率要比以上两种高。

<%# ((DataRowView)Container.DataItem)["xxxx"]%>

很有用的,这样可以在前台页面做好多事情了。

还要记住要这样用必须要在前台页面导入名称空间System.Data,否则会生成错误信息。

<%@ Import namespace="System.Data" %>

这种用法其实和<%# ((DictionaryEntry)Container.DataItem).Key%>是一个道理。

关键是Container这个东西,它的名称空间是System.ComponentModel。

3.DataBinder.Eval和Container.DataItem的区别

DataBinder.Eval(Container.DataItem,"Name")和 Container.DataItem("Name")有什么区别?

DataBinder是System.Web里面的一个静态类,它提供了 Eval方法用于简化数据绑定表达式的编写,但是它使用的方式是通过Reflection等开销比较大的方法来达到易用性,因此其性能并不是最好的。而 Container则根本不是任何一个静态的对象或方法,它是ASP.NET页面编译器在数据绑定事件处理程序内部声明的局部变量,其类型是可以进行数据 绑定的控件的数据容器类型(如在Repeater内部的数据绑定容器叫RepeaterItem),在这些容器类中基本都有DataItem属性,因此你 可以写Container.DataItem,这个属性返回的是你正在被绑定的数据源中的那个数据项。如果你的数据源是DataTable,则这个数据项 的类型实际是DataRowView。

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

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

或者如下:

<%# data-binding expression %>

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

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

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

XPath 方法支持对XML类型的数据源提供支持。

数据绑定表达式都可以出现在页面的哪个位置呢?

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

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

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

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

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

<form >

  • <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
  • <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  • <html xmlns="http://www.w3.org/1999/xhtml" >
  • <head runat="server">
  • <title>无标题页</title>
  • <mce:script language ="javascript" type="text/javascript"><!--
  • function GetStr()
  • {
  • var a;
  • a = '';
  • a='<%#CSharpToJavascript()%>' //调用c#的方法
  • alert(a);
  • }
  • // --></mce:script>
  • </head>
  • <body>
  • <form runat="server">
  • <div>
  • <input type="button" value="Javascript调用c#的方法!" onclick="GetStr()" /</div>
  • </form>
  • </body>
  • </html>
  • using System;
  • using System.Data;
  • using System.Configuration;
  • using System.Collections;
  • using System.Web;
  • using System.Web.Security;
  • using System.Web.UI;
  • using System.Web.UI.WebControls;
  • using System.Web.UI.WebControls.WebParts;
  • using System.Web.UI.HtmlControls;
  • public partial class Default2 : System.Web.UI.Page
  • {
  • protected void Page_Load(object sender, EventArgs e)
  • {
  • Page.DataBind();//方法有返回值的要先绑定,才能实现Javascript调用c#的方法!
  • }
  • public string CSharpToJavascript()
  • {
  • return "Javascript 调用c#的方法!";
  • }
  • }