關於資料繫結運算式
一年沒更新過了,之前也是認為不錯的文章轉一下,認為這樣可能理解的效果會更好些,今天偶然看到一篇關於資料繫結的,覺得不錯,就拿來貼下.也算是對自己開始重新努力的一個標誌:)
從一點點開始做起吧.讓部落格園給個見證.
原文開始:)
今天談下.NET中的資料繫結運算式。
資料繫結運算式必須包含在<%#和%>字元之間。格式如下:
<tagprefix:tagname property='<%# data-binding expression %>' runat="server" />
或者如下:
<%# 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("資料庫中某個表的某個欄位")等,那麼必須把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)["欄位名"] %>的效能最好。