關於資料繫結運算式

來源:互聯網
上載者:User
關於資料繫結運算式

一年沒更新過了,之前也是認為不錯的文章轉一下,認為這樣可能理解的效果會更好些,今天偶然看到一篇關於資料繫結的,覺得不錯,就拿來貼下.也算是對自己開始重新努力的一個標誌:)

從一點點開始做起吧.讓部落格園給個見證.
原文開始:)

今天談下.NET中的資料繫結運算式。
資料繫結運算式
必須包含在<%#和%>字元之間。格式如下:

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

或者如下:

<%# data-binding expression %>

ASP.NET 支援分層資料繫結模型,資料繫結運算式使用 EvalBind 方法將資料繫結到控制項,並將更改提交回資料庫。
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("資料庫中某個表的某個欄位")等,那麼必須把TextBox1放在某個迴圈顯示的控制項的模板中才正確,否則會提示:Eval()、XPath() 和 Bind() 這類資料繫結方法只能在資料繫結控制項的上下文中使用。其實就是想讓你把TextBox1放在像Repeater,DataList,GridView這樣的控制項的模板中。

二,資料繫結綁定運算式包含在在頁面中的任何位置。例如:

<form id="form1" runat="server">
    <div>
     <%#Eval("資料繫結運算式1")%>  
     <%#Eval("資料繫結運算式2")%>        
    </div> 
</form>

同樣遵循"一"的注意條款。
如果此時的資料繫結運算式是Eval("資料庫中某個表的某個欄位")等,那麼必須把 <%#Eval("資料繫結運算式1")%>   <%#Eval("資料繫結運算式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#的方法!" onclick="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這樣的控制項等,此時只需要把屬性DataSource='<%# 數組名%>' 。
4,可以是一個運算式
例如:Person是一個對象,Name和City是它的2個屬性,則資料繫結運算式可以這樣寫:
<%#(Person.Name + " " + Person.City)%>。
5,可以是一個方法
例如:<%#GetUserName()%>。GetUserName()是一個已經定義的C#方法,一般要求有傳回值。
6,可以是用Eval,DateBind.Eval取得的資料表的欄位,這個是最常見的了,不再舉例。

注意:如果資料繫結運算式作為屬性的值,只要資料繫結運算式中沒有出現雙引號,那麼<%#資料繫結運算式%>的最外層用雙引號或者單引號都可以。如果資料繫結運算式中出現雙引號,則<%#資料繫結運算式%>的最外層最好要用單引號。

與資料庫有關的資料繫結運算式的常用方法?

1,<%#DataBind.Eval(Container.DataItem,"欄位名")%>
      <%#DataBind.Eval(Container.DataItem,"欄位名","{0:c}") %>
     還有2種不常用的:
      <%# DataBinder.Eval(Container,"DataItem.欄位名")%> 
      <%# DataBinder.Eval(Container,"DataItem.欄位名",{0:c})%> 
      Container.DataItem相當於資料庫中某個表中的一行記錄,而一行可以有很多列。
      最後一個參數和         使用三目運算子?:的例子:
 <%# DataBinder.Eval(Container.DataItem, "欄位名").ToString().Trim().Length>16?DataBinder.Eval(Container.DataItem, "欄位名").ToString().Trim().Substring(0,16):DataBinder.Eval(Container.DataItem, "欄位名").ToString().Trim() %>

2,<%#Eval("欄位名")%>
     <%#Eval("欄位名","{0:c}")%>
     .NET 2.0新出現的一個方法。和DataBind.Eval()等價。
     最後一個參數和

string GetUserPhoto(object photoPath)
{
  if (photoPath == DBNull.Value)<%#((DataRowView)Container.DataItem)["欄位名"] %>

  {
      return "<img src='Images/none.gif'>";
  }
  else
  {
    return "<img src='Upload/" +photoPath.ToString() + "'>";
  }
}

 3, <%#((DataRowView)Container.DataItem)["欄位名"] %>
      <%# string.Format("{0:c}", ((DataRowView)Container.DataItem)["欄位名"])%>
          用       
       類型轉換例子:<%# (int)((DataRowView)Container.DataItem)["欄位名1"]*(int)((DataRowView)Container.DataItem)["欄位名2"]%>    意思是2個欄位相乘。
    
上面三種Binder 方法的效率:Eval方法執行時候會調用DataBinder.Eval方法,DataBinder.Eval方法在運行時使用反射執行後期綁定計算,會導致效能明顯下降。所以會導致效能明顯下降。所以三者中<%#((DataRowView)Container.DataItem)["欄位名"] %>的效能最好。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.