常用的前臺資料繫結方法

wl1121發表於2009-06-27

1、使用後臺的類
GridView繫結資料時解決文字過長問題,用於新文標題...效果
首先,寫一個抽象類,一個靜態函式。
public abstract class TStringOp
{
    public static string trunc(string inStr, int len)
    {
        if (inStr.Length > len)
        {
            inStr = inStr.Substring(0, len)+"...";
        }
        return inStr;
    }
}
然後,寫在資料繫結的時候呼叫之:
<asp:Label ID="lblIntro" runat="server" Text='<%# TStringOp.trunc(Eval("siteIntro").ToString(),20) %>'
2、繫結資料來源的欄位和繫結後臺的變數和後臺的函式和混合使用
<table width="100%" border="0" cellspacing="0" cellpadding="0">
                <tr>
                  <td width="17" rowspan="2"><img src="Images/jiantou11.gif" width="15" height="11"></td>
                  <td ><a href='<%# ChannelUrl(Eval("CategoryID").ToString(),Eval("OutLink").ToString()) %>' class = "t9" style="color:Black;FONT-SIZE: 14px;LINE-HEIGHT: 25px;" target='<%=target %>'><%# Eval("CategoryName") %></a></td>
                </tr>
             </table>
說明:<%=target %>中target是後臺的變數
<%# ChannelUrl(Eval("CategoryID").ToString())中ChannelUrl是後臺的函式


靈活的運用資料繫結操作 

繫結到簡單屬性:<%#UserName%> 

繫結到集合:<asp:ListBox datasource='<%# myArray%>' runat="server"> 

繫結到表示式:<%#(class1.property1.ToString() + "," + class1.property2.ToString())%> 

繫結到方法返回值:<%# GetSafestring(str) %> 

繫結到Hashtable:<%# ((DictionaryEntry)Container.DataItem).Key%> 

繫結到ArrayList:<%#Container.DataItem %> 

若陣列裡裡放的是物件則可能要進行必要的轉換後再繫結如: 

<%#((物件型別)Container.DataItem).屬性%> 

繫結到DataView,DataTable,DataSet: 

<%#((DataRowView)Container.DataItem)["欄位名"]%>或 

<%#((DataRowView)Container.DataItem).Rows[0]["欄位名"]%> 

要格式化則: 

<%#string.Format("格式",((DataRowView)Container.DataItem)["欄位名"])%> 

<%#DataBinder.Eval(Container.DataItem,"欄位名","格式")%> 

繫結到DataReader: 

<%#((IDataReader)Container.DataItem).欄位名%> 

當然為了方便一般使用最多的就是DataBinder類的Eval方法了.不過這樣對於同時要繫結大量的資料效率要低一些 

在繫結資料時經常會用到這個句程式:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%> 

今天又學到一種,而且微軟也說這種方法的效率要比以上兩種高。 

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

很有用的,這樣可以在前臺頁面做好多事情了。 

還要記住要這樣用必須要在前臺頁面匯入名稱空間System.Data,否則會生成錯誤資訊。 

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

這種用法其實和<%# ((DictionaryEntry)Container.DataItem).Key%>是一個道理。 

繫結到DataSet、DataTable時: 

<%#((System.Data.DataRowView)Container.DataItem)["欄位名"]%> 

<%#((System.Data.DataRowView)Container.DataItem)[索引]%> 

繫結到DataReader時: 

<%#((System.Data.Common.DbDataRecord)Container.DataItem)[索引]%> 

<%#((System.Data.Common.DbDataRecord)Container.DataItem)["欄位名"]%> 

關鍵是Container這個東西,它比較神祕。它的名稱空間是System.ComponentModel。對於它我還需要進一步理解。 

DataGrid控制元件,在ItemTemplate顯示資料時, DataBinder.Eval(Container.DataItem,"Name")和Container.DataItem("Name")有什麼區別? 

DataBinder是System.Web裡面的一個靜態類,它提供了Eval方法用於簡化資料繫結表示式的編寫,但是它使用的方式是通過 Reflection等開銷比較大的方法來達到易用性,因此其效能並不是最好的。而Container則根本不是任何一個靜態的物件或方法,它是 ASP.NET頁面編譯器在資料繫結事件處理程式內部宣告的區域性變數,其型別是可以進行資料繫結的控制元件的資料容器型別(如在Repeater內部的資料綁 定容器叫RepeaterItem),在這些容器類中基本都有DataItem屬性,因此你可以寫Container.DataItem,這個屬性返回的 是你正在被繫結的資料來源中的那個資料項。如果你的資料來源是DataTable,則這個資料項的型別實際是DataRowView

在繫結資料時經常會用到這個句程式:<%# DataBinder.Eval(Container.DataItem,"xxxx")%>或者<%# DataBinder.Eval(Container,"DataItem.xxxx")%> 

今天又學到一種,而且微軟也說這種方法的效率要比以上兩種高。 

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

很有用的,這樣可以在前臺頁面做好多事情了。 

還要記住要這樣用必須要在前臺頁面匯入名稱空間System.Data,否則會生成錯誤資訊。 

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

這種用法其實和<%# ((DictionaryEntry)Container.DataItem).Key%>是一個道理。 

Text='<%# DataBinder.Eval(Container.DataItem, "欄位") %>' 
這樣的方法是最快的 

Text='<%# GetPrice() %>' 
也可以繫結方法,但方法要是public的 

Text='<%# "CarDetails.aspx?CarID=" + DataBinder.Eval(Container.DataItem, "CarID") %>' 
還可以連線多個欄位
 

相關文章