數據綁定服務器控件的 幾種方式

數據綁定服務器控件

 

 


數據綁定概述和語法

ASP.NET 引入了新的聲明性數據綁定語法。這種非常靈活的語法允許開發人員不僅可以綁定到數據源,而且可以綁定到簡單屬性、集合、表達式甚至是從方法調用返回的結果。下表顯示了新語法的一些示例。

 

儘管該語法看起來與 ASP 的 Response.Write 快捷方式 <%= %> 相似,但其行爲完全不同。ASP Response.Write 快捷方式語法在處理頁時計算,而 ASP.NET 數據綁定語法僅在調用 DataBind 方法時計算。

DataBind和所有服務器控件的方法。當在父控件上調用 DataBind 時,它級聯到該控件的所有子控件。例如,DataList1.DataBind() 將因此對 DataList 模板中的每一控件調用 DataBind 方法。在上調用 DataBindPage.DataBind() 或只是 DataBind() — 會導致計算頁上的所有數據綁定表達式。通常從 Page_Load 事件調用 DataBind,如下例所示。

<script language="JavaScript" type="text/javascript"> function doClick(index, numTabs, id) { document.all("tab" + id, index).className = "tab"; for (var i=1; i < numTabs; i++) { document.all("tab" + id, (index + i) % numTabs).className = "backtab"; } document.all("code" + id, index).style.display = ""; for (var j=1; j < numTabs; j++) { document.all("code" + id, (index + j) % numTabs).style.display = "none"; } } </script>

protected void Page_Load(Object Src, EventArgs E) {
    DataBind();
}
Protected Sub Page_Load(Src As Object, E As EventArgs)
    DataBind()
End Sub
protected function Page_Load(Src:Object, E:EventArgs) : void {
    DataBind();
}
C# VB JScript  

如果綁定表達式在運行時計算爲預期的數據類型,則可以在 .aspx 頁的聲明節中的幾乎任何位置使用綁定表達式。上面的簡單屬性、表達式和方法示例在計算時向用戶顯示文本。這些情況下,數據綁定表達式必須計算爲 String 類型的值。在集合示例中,數據綁定表達式計算爲 ListBoxDataSource 屬性的有效類型值。您可能會發現有必要轉換綁定表達式中的類型值以產生所需的結果。例如,如果 count 是整數:

 

Number of Records: <%# count.ToString() %>


綁定到簡單屬性

ASP.NET 數據綁定語法支持綁定到公共變量、的屬性和頁上其他控件的屬性。

下面的示例說明如何綁定到公共變量和頁上的簡單屬性。注意這些值在 DataBind() 調用前初始化。

  C# DataBind1.aspx
[] | []
源碼
<html>
<head>
 
    
<script language="C#" runat="server">

        
void Page_Load(Object sender, EventArgs e) {
            Page.DataBind();
        }

        
        string custID
{
            get 
{
                
return "ALFKI";
            }

        }

        
        
int orderCount{
            get 
{
                
return 11;
            }

        }



    
</script>

</head>
<body>

    
<h3><font face="宋體">到頁屬性的數據綁定</font></h3>

    
<form runat=server>
    
        客戶:
<b><%# custID %></b><br>
        未結的訂單:
<b><%# orderCount %></b>

    
</form>

</body>
</html>

 

 

下面的示例說明如何綁定到另一控件的屬性。

  C# DataBind2.aspx
[] | []

<html>
<head>
 
    
<script language="C#" runat="server">

        
void SubmitBtn_Click(Object sender, EventArgs e) {
        
          
// 僅調用“Page.DataBind”,而不是從“StateList”
          
// 中顯式取出變量,然後操作標籤控件。
          
// 這將計算頁內所有的 <%# %> 表達式
          
          Page.DataBind();
        }


    
</script>

</head>
<body>

    
<h3><font face="宋體">到另一個服務器控件的屬性的數據綁定</font></h3>

    
<form runat=server>

        
<asp:DropDownList id="StateList" runat="server">
          
<asp:ListItem>CA</asp:ListItem>
          
<asp:ListItem>IN</asp:ListItem>
          
<asp:ListItem>KS</asp:ListItem>
          
<asp:ListItem>MD</asp:ListItem>
          
<asp:ListItem>MI</asp:ListItem>
          
<asp:ListItem>OR</asp:ListItem>
          
<asp:ListItem>TN</asp:ListItem>
          
<asp:ListItem>UT</asp:ListItem>
        
</asp:DropDownList>
        
        
<asp:button Text="提交" OnClick="SubmitBtn_Click" runat=server/>
        
        
<p>
        
        選定的州:
<asp:label text='<%# StateList.SelectedItem.Text %>' runat=server/>
        
    
</form>

</body>
</html>

 

 

DataGridListBoxHTMLSelect 這樣的列表服務器控件將集合用作數據源。下面的示例說明如何綁定到通常的公共語言運行庫集合類型。這些控件只能綁定到支持 IEnumerableICollectionIListSource 接口的集合。最常見的是綁定到 ArrayListHashtableDataViewDataReader

 

下面的示例說明如何綁定到 ArrayList

  C# DataBind3.aspx
[] | []
<html>
<head>
 

    
<script language="C#" runat="server">

        
void Page_Load(Object Sender, EventArgs E) {

            
if (!Page.IsPostBack) {

               ArrayList values 
= new ArrayList();

               values.Add (
"IN");
               values.Add (
"KS");
               values.Add (
"MD");
               values.Add (
"MI");
               values.Add (
"OR");
               values.Add (
"TN");

               DropDown1.DataSource 
= values;
               DropDown1.DataBind();
            }

        }


        
void SubmitBtn_Click(Object sender, EventArgs e) {
           Label1.Text 
= "您選擇了:" + DropDown1.SelectedItem.Text;
        }


    
</script>

</head>
<body>

    
<h3><font face="宋體">數據綁定 DropDownList</font></h3>

    
<form runat=server>
    
        
<asp:DropDownList id="DropDown1" runat="server" />

        
<asp:button Text="提交" OnClick="SubmitBtn_Click" runat=server/>

        
<p>
        
        
<asp:Label id=Label1 font-name="宋體" font-size="10.5pt" runat="server" />

    
</form>

</body>
</html>


 

下面的示例說明如何綁定到 DataView。注意 DataView 類在 System.Data 命名空間中定義。

  C# DataBind4.aspx
[] | []
<%@ Import namespace="System.Data" %>

<html>
<head>
 

    
<script language="C#" runat="server">

        
void Page_Load(Object sender, EventArgs e ) {
        
            
if (!Page.IsPostBack) {
            
                DataTable dt 
= new DataTable();
                DataRow dr;

                dt.Columns.Add(
new DataColumn("整數值"typeof(Int32)));
                dt.Columns.Add(
new DataColumn("字符串值"typeof(string)));
                dt.Columns.Add(
new DataColumn("日期時間值"typeof(DateTime)));
                dt.Columns.Add(
new DataColumn("布爾值"typeof(bool)));

                
for (int i = 1; i <= 9; i++{
                
                    dr 
= dt.NewRow();

                    dr[
0= i;
                    dr[
1= "項 " + i.ToString();
                    dr[
2= DateTime.Now;
                    dr[
3= (i % 2 != 0? true : false;

                    dt.Rows.Add(dr);
                }

           
                dataGrid1.DataSource 
= new DataView(dt);
                dataGrid1.DataBind();
            }

        }


    
</script>

</head>
<body>

    
<h3><font face="宋體">到 DataView 的數據綁定</font></h3>

    
<form runat=server>

        
<asp:DataGrid id="dataGrid1" runat="server"
          BorderColor
="black"
          BorderWidth
="1"
          GridLines
="Both"
          CellPadding
="3"
          CellSpacing
="0"
          HeaderStyle-BackColor
="#aaaadd"
        
/>

    
</form>

</body>
</html>

 

下面的示例說明如何綁定到 Hashtable

  C# DataBind5.aspx
[] | []

 

<html>
<head>
 

    
<script language="C#" runat="server">

        
void Page_Load(Object sender, EventArgs e) {
            
if (!Page.IsPostBack) {

                Hashtable h 
= new Hashtable();
                h.Add (
"鍵 1""值 1");
                h.Add (
"鍵 2""值 2");
                h.Add (
"鍵 3""值 3");

                MyDataList.DataSource 
= h;
                MyDataList.DataBind();
            }

        }


    
</script>

</head>
<body>

    
<h3><font face="宋體">到哈希表的數據綁定</font></h3>

    
<form runat=server>

        
<asp:DataList id="MyDataList" runat="server"
          BorderColor
="black"
          BorderWidth
="1"
          GridLines
="Both"
          CellPadding
="4"
          CellSpacing
="0"
          
>

            
<ItemTemplate>
                
<%# ((DictionaryEntry)Container.DataItem).Key %> :
                
<%# ((DictionaryEntry)Container.DataItem).Value %>
            
</ItemTemplate>

        
</asp:DataList>

    
</form>

</body>
</html>


 

通常需要在綁定到頁或控件之前操作數據。下面的示例說明如何綁定到表達式和方法的返回值。

  C# DataBind6.aspx
[] | []
<html>
<head>
 

    
<script language="C#" runat="server">

        
void Page_Load(Object Src, EventArgs E) {

            
if (!Page.IsPostBack) {

               ArrayList values 
= new ArrayList();

               values.Add (
0);
               values.Add (
1);
               values.Add (
2);
               values.Add (
3);
               values.Add (
4);
               values.Add (
5);
               values.Add (
6);

               DataList1.DataSource 
= values;
               DataList1.DataBind();
            }

        }


        String EvenOrOdd(
int number) {
            
if ((number % 2== 0)
              
return "偶數";
            
else
              
return "奇數";
        }


    
</script>

</head>
<body>

    
<h3><font face="宋體">到方法和表達式的數據綁定</font></h3>

    
<form runat=server>

      
<asp:DataList id="DataList1" runat="server"
        BorderColor
="black"
        BorderWidth
="1"
        GridLines
="Both"
        CellPadding
="3"
        CellSpacing
="0"
        
>

        
<ItemTemplate>
          數字值:
<%# Container.DataItem %>
          偶
/奇:<%# EvenOrOdd((int) Container.DataItem) %>
        
</ItemTemplate>

      
</asp:datalist>

    
</form>

</body>
</html>

 


DataBinder.Eval
 

ASP.NET 框架提供了一種靜態方法,計算後期綁定的數據綁定表達式並且可選擇將結果格式化爲字符串。DataBinder.Eval 很方便,因爲它消除了開發人員爲強迫將值轉換爲所需的數據類型而必須做的許多顯式轉換。這在數據綁定模板列表內的控件時尤其有用,因爲通常數據行和數據字段的類型都必須轉換。

請看下面的示例,本例中整數將顯示爲貨幣字符串。使用標準的 ASP.NET 數據綁定語法,必須首先轉換數據行的類型以便檢索數據字段 IntegerValue。下一步,將此作爲參數傳遞給 String.Format 方法。

<%# String.Format("{0:c}", ((DataRowView)Container.DataItem)["IntegerValue"]) %>
<%# String.Format("{0:c}", (CType(Container.DataItem, DataRowView)("IntegerValue"))) %>
<%# String.Format("{0:c}", (DataRowView(Container.DataItem))["IntegerValue"]) %>
C# VB JScript  

 

該語法可能比較複雜,難以記憶。相反,DataBinder.Eval 只是一個具有三個參數的方法:數據項的命名容器、數據字段名和格式字符串。在像 DataListDataGridRepeater 這樣的模板列表中,命名容器始終是 Container.DataItemPage 是另一個可與 DataBinder.Eval 一起使用的命名容器。

 

<%# DataBinder.Eval(Container.DataItem, "IntegerValue", "{0:c}") %>
<%# DataBinder.Eval(Container.DataItem, "IntegerValue", "{0:c}") %>
<%# DataBinder.Eval(Container.DataItem, "IntegerValue", "{0:c}") %>
C# VB JScript  

 

格式字符串參數是可選的。如果省略它,則 DataBinder.Eval 返回對象類型的值,如下例所示。

 

<%# (bool)DataBinder.Eval(Container.DataItem, "BoolValue") %>
<%# CType(DataBinder.Eval(Container.DataItem, "BoolValue"), Boolean) %>
<%# Boolean(DataBinder.Eval(Container.DataItem, "BoolValue")) %>
C# VB JScript  

 

DataBinder.Eval 會對標準數據綁定語法帶來很明顯的性能損失,因爲它使用後期綁定反射,注意這一點很重要。使用 DataBinder.Eval 時需謹慎,尤其是在不需要字符串格式化時。

 
C# DataBind7.aspx

[運行示例] | [查看源代碼]

本節小結

  1. ASP.NET 聲明性數據綁定語法使用 <%# %> 表示法。
  2. 可以綁定到數據源、頁或其他控件的屬性、集合、表達式以及從方法調用返回的結果。
  3. 列表控件可以綁定到支持 ICollectionIEnumerableIListSource 接口的集合,如 ArrayListHashtableDataViewDataReader
  4. DataBinder.Eval 是用於晚期綁定的靜態方法。它的語法可能比標準數據綁定語法簡單,但性能較低。


綁定到集合和列表

綁定表達式或方法
發佈了28 篇原創文章 · 獲贊 3 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章