淺談.NET中的數據綁定表達式

淺談.NET中的數據綁定表達式 

一,可以將數據綁定表達式包含在服務器控件或者普通的html元素的開始標記中屬性名/屬性值對的值側。二,數據綁定綁定表達式包含在在頁面中的任何位置。三,可以將數據綁定表達式包含在Javascript代碼中,從而實現在Javascript中調用C#或者VB.NET的方法。

數據綁定表達式必須包含在<%#和%>字符之間。格式如下:

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

或者如下:此時只需要把屬性DataSource='<%# 數組名%>' 。

4,可以是一個表達式

例如:Person是一個對象,Name和City是它的2個屬性,則數據綁定表達式可以這樣寫:

<%#(Person.Name + " " + Person.City)%>。

5,可以是一個方法

例如:<%#GetUserName()%>。GetUserName()是一個已經定義的C#方法,一般要求有返回值。

6,可以是用Eval,DateBind.Eval取得的數據表的字段,這個是最常見的了,不再舉例。

注意:如果數據綁定表達式作爲屬性的值,只要數據綁定表達式中沒有出現雙引號,那麼<%#數據綁定表達式%>的最外層用雙引號或者單引號都可以。如果數據綁定表達式中出現雙引號,則<%#數據綁定表達式%>的最外層最好要用單引號。

與數據庫有關的數據綁定表達式的常用方法?

1,<%#DataBind.eval_r(Container.DataItem,"字段名")%>

      <%#DataBind.eval_r(Container.DataItem,"字段名","{0:c}") %>

     還有2種不常用的:

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

      <%# DataBinder.eval_r(Container,"DataItem.字段名",{0:c})%> 

      Container.DataItem相當於數據庫中某個表中的一行記錄,而一行可以有很多列。

      最後一個參數和 String.Format的形式一樣。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點後三爲,一次類推。

         使用三目運算符?:的例子:

 <%# DataBinder.eval_r(Container.DataItem, "字段名").ToString().Trim().Length>16?DataBinder.eval_r(Container.DataItem, "字段名").ToString().Trim().Substring(0,16):DataBinder.eval_r(Container.DataItem, "字段名").ToString().Trim() %>

2,<%#eval_r("字段名")%>

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

     .NET 2.0新出現的一個方法。和DataBind.eval_r()等價。

     最後一個參數和 String.Format的形式一樣。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點後三位,一次類推。

     使用三目運算符的例子:

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

 性別字段類型爲:是/否(Access),bit(sql server)

      使用方法調用的例子:

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

     GetUserPhoto()的定義:

3, <%#((DataRowView)Container.DataItem)["字段名"] %>

      <%# string.Format("{0:c}", ((DataRowView)Container.DataItem)["字段名"])%>

          用String.Format方法設定字段的顯示樣式。例如c代表貨幣,p代表百分號,d代表短日期格式顯示,f代表浮點數現實,f3代表小數點後三爲,一次類推。

 

       類型轉換例子:<%# (int)((DataRowView)Container.DataItem)["字段名1"]*(int)((DataRowView)Container.DataItem)["字段名2"]%>    意思是2個字段相乘。

 

上面三種綁定方法的效率:Eval方法執行時候會調用DataBinder.Eval方法,DataBinder.Eval方法在運行時使用反射執行後期綁定計算,會導致性能明顯下降。所以會導致性能明顯下降。所以三者中<%#((DataRowView)Container.DataItem)["字段名"] %>的性能最好。

 

<%# data-binding expression %>

ASP.NET 支持分層數據綁定模型,數據綁定表達式使用 Eval 和 Bind 方法將數據綁定到控件,並將更改提交回數據庫。

Eval 方法是靜態單向(只讀)方法,所以Eval 函數用於單向(只讀)綁定,該方法採用數據字段的值作爲參數並將其作爲字符串返回。

Bind 方法支持讀/寫功能,所以Bind 函數用於雙向(可更新)綁定。該方法可以檢索數據綁定控件的值並將任何更改提交回數據庫。

XPath 方法支持對XML類型的數據源提供支持。

數據綁定表達式都可以出現在頁面的哪個位置呢?

一,可以將數據綁定表達式包含在服務器控件或者普通的html元素的開始標記中屬性名/屬性值對的值側。例如:

<asp:TextBox ID="TextBox1" runat="server" Text='<%#數據綁定表達式%>' ></asp:TextBox><br />

注意條款:此時數據的綁頂表達式可以是一個變量,也可以是一個帶返回值的C#或者VB.NET方法,還可以是某個控件的某個屬性的值,也可以是C#或者VB.NET對象的某個字段或者屬性的值等等。當然也可以直接就是一個字符串,例如"hello"。

如果此時的數據綁定表達式是eval_r("數據庫中某個表的某個字段")等,那麼必須把TextBox1放在某個循環顯示的控件的模板中才正確,否則會提示:eval_r()、XPath() 和 Bind() 這類數據綁定方法只能在數據綁定控件的上下文中使用。其實就是想讓你把TextBox1放在像Repeater,DataList,GridView這樣的控件的模板中。

二,數據綁定綁定表達式包含在在頁面中的任何位置。例如:

<form id="form1" runat="server">

    <div>

     <%#eval_r("數據綁定表達式1")%>  

     <%#eval_r("數據綁定表達式2")%>        

    </div> 

</form>

同樣遵循"一"的注意條款。

如果此時的數據綁定表達式是eval_r("數據庫中某個表的某個字段")等,那麼必須把 <%#eval_r("數據綁定表達式1")%>   <%#eval_r("數據綁定表達式2")%>  放在像Repeater,DataList,GridView這樣的控件的模板中。

三,可以將數據綁定表達式包含在Javascript代碼中,從而實現在Javascript中調用C#或者VB.NET的方法。例如:

Deafult2.aspx:

<%@ 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>

    <script language ="javascript" type="text/javascript">

    function GetStr()

    {

       var a; 

       a = ''; 

       a='<%#CSharpToJavascript()%>'         //調用c#的方法

       alert(a);

    }

    </script>    

</head>

<body>

    <form id="form1" runat="server">

    <div>

        <input id="Button1" type="button" value="Javascript調用c#的方法!" οnclick="GetStr()" /</div> 

    </form>

</body>

</html>

Default2.cs:

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#的方法!";

    }

}

數據綁定表達式都可以是什麼類型呢?

1,可以是一個變量

例如:<asp:Label ID="Label1" runat="server" Text="<%#變量名%>"></asp:Label>

2,可以是服務器控件的屬性值

例如: <asp:Label ID="Label1" runat="server" Text="<%#TextBox2.Text %>"></asp:Label>

3,可以是一個數組等集合對象

例如把一個數組綁定到列表控件,例如ListBox等,或者Repeater,DataList,GridView這樣的控件等,

string GetUserPhoto(object photoPath)

{

  if (photoPath == DBNull.Value)<%#((DataRowView)Container.DataItem)["字段名"] %>

  {

      return "<img src='Images/none.gif'>";

  }

  else

  {

    return "<img src='Upload/" +photoPath.ToString() + "'>";

  }

}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章