中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • ASP.NET框架中的數據綁定概要與數據綁定表達式的使用方法

ASP.NET框架中的數據綁定概要與數據綁定表達式的使用方法

發布時間:2021-07-02 16:23:36 來源:億速云 閱讀:135 作者:chen 欄目:開發技術

本篇內容介紹了“ASP.NET框架中的數據綁定概要與數據綁定表達式的使用方法”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

<%# %> 語法

ASP.NET 介紹了一種新的聲明性語法 <%# %>。該語法是在 .aspx 頁中使用數據綁定的基礎。所有數據綁定表達式都必須包含在這些字符中。下面的列表包含從多個源進行簡單數據綁定的示例:
簡單屬性(用于客戶的語法):

<%# custID %>

集合(用于訂單的語法):

<asp:ListBox id="List1" datasource='<%# myArray %>' runat="server">

 表達式(用于聯系人的語法):

<%# ( customer.First Name + " " + customer.LastName ) %>

     
方法結果(用于未結清余額的語法):

<%# GetBalance(custID) %>

     
在前面的示例中,<%# %> 內聯標記用于指示將把特定數據源中的信息放在 .aspx 頁中的什么位置。以下數據綁定示例使用 TextBox Web 服務器控件:

<asp:textbox id=txt text="<%# custID %>" runat=server />


Page.DataBind() versus Control.DataBind()

確定特定數據源并設置 .aspx 頁上的對象之后,您必須將數據綁定到數據源。您可以使用 Page.DataBind 或 Control.DataBind 方法將數據綁定到數據源。

這兩種方法的使用方式很相似。主要差別在于:調用 Page.DataBind 方法后,所有數據源都將綁定到它們的服務器控件。在顯式調用 Web 服務器控件的 DataBind 方法或在調用頁面級的 Page.DataBind 方法之前,不會有任何數據呈現給控件。通常,可以從 Page_Load 事件調用 Page.DataBind(或 DataBind)。

數據綁定表達式深入
數據綁定表達式包含在 <%# 和 %> 分隔符之內,并使用 Eval 和 Bind 函數。Eval 函數用于定義單向(只讀)綁定。Bind 函數用于定義雙向(可更新)綁定。除了通過在數據綁定表達式中調用 Eval 和 Bind 方法執行數據綁定外,還可以調用 <%# 和 %> 分隔符之內的任何公共范圍代碼,以在頁面處理過程中執行該代碼并返回一個值。
調用控件或 Page 類的 DataBind 方法時,會對數據綁定表達式進行解析。對于有些控件,如 GridView、DetailsView 和 FormView 控件,會在控件的 PreRender 事件期間自動解析數據綁定表達式,不需要顯式調用 DataBind 方法。
下面的代碼示例演示如何將數據綁定表達式與 ItemTemplate 中的 FormView 控件結合使用。

<asp:FormView ID="FormView1"
 DataSourceID="SqlDataSource1"
 DataKeyNames="ProductID"   
 RunAt="server">

 <ItemTemplate>
  <table>
   <tr><td align="right"><b>Product ID:</b></td>    <td><%# Eval("ProductID") %></td></tr>
   <tr><td align="right"><b>Product Name:</b></td>   <td><%# Eval("ProductName") %></td></tr>
   <tr><td align="right"><b>Category ID:</b></td>   <td><%# Eval("CategoryID") %></td></tr>
   <tr><td align="right"><b>Quantity Per Unit:</b></td><td><%# Eval("QuantityPerUnit") %></td></tr>
   <tr><td align="right"><b>Unit Price:</b></td>    <td><%# Eval("UnitPrice") %></td></tr>
  </table>         
 </ItemTemplate>         
</asp:FormView>

使用 Eval 方法
Eval 方法可計算數據綁定控件(如 GridView、DetailsView 和 FormView 控件)的模板中的后期綁定數據表達式。在運行時,Eval 方法調用 DataBinder 對象的 Eval 方法,同時引用命名容器的當前數據項。命名容器通常是包含完整記錄的數據綁定控件的最小組成部分,如 GridView 控件中的一行。因此,只能對數據綁定控件的模板內的綁定使用 Eval 方法。
Eval 方法以數據字段的名稱作為參數,從數據源的當前記錄返回一個包含該字段值的字符串。可以提供第二個參數來指定返回字符串的格式,該參數為可選參數。字符串格式參數使用為 String 類的 Format 方法定義的語法。

使用 Bind 方法
Bind 方法與 Eval 方法有一些相似之處,但也存在很大的差異。雖然可以像使用 Eval 方法一樣使用 Bind 方法來檢索數據綁定字段的值,但當數據可以被修改時,還是要使用 Bind 方法。
在 ASP.NET 中,數據綁定控件(如 GridView、DetailsView 和 FormView 控件)可自動使用數據源控件的更新、刪除和插入操作。例如,如果已為數據源控件定義了 SQL Select、Insert、Delete 和 Update 語句,則通過使用 GridView、DetailsView 或 FormView 控件模板中的 Bind 方法,就可以使控件從模板中的子控件中提取值,并將這些值傳遞給數據源控件。然后數據源控件將執行適當的數據庫命令。出于這個原因,在數據綁定控件的 EditItemTemplate 或 InsertItemTemplate 中要使用 Bind 函數。
Bind 方法通常與輸入控件一起使用,例如由編輯模式中的 GridView 行所呈現的 TextBox 控件。當數據綁定控件將這些輸入控件作為自身呈現的一部分創建時,該方法便可提取輸入值。
Bind 方法采用數據字段的名稱作為參數,從而與綁定屬性關聯,如下面的示例所示:

<EditItemTemplate>
 <table>
  <tr>
   <td align=right>
    <b>Employee ID:</b>
   </td>
   <td>
    <%# Eval("EmployeeID") %>
   </td>
  </tr>
  <tr>
   <td align=right>
    <b>First Name:</b>
   </td>
   <td>
    <asp:TextBox ID="EditFirstNameTextBox" RunAt="Server"
     Text='<%# Bind("FirstName") %>' />
   </td>
  </tr>
  <tr>
   <td align=right>
    <b>Last Name:</b>
   </td>
   <td>
    <asp:TextBox ID="EditLastNameTextBox" RunAt="Server"
      Text='<%# Bind("LastName") %>' />
   </td>
  </tr>
  <tr>
   <td colspan="2">
    <asp:LinkButton ID="UpdateButton" RunAt="server"
     Text="Update" CommandName="Update" />
    &nbsp;
    <asp:LinkButton ID="CancelUpdateButton" RunAt="server"
     Text="Cancel" CommandName="Cancel" />
   </td>
  </tr>
 </table>
</EditItemTemplate>

單擊行的 Update 按鈕時,使用 Bind 語法綁定的每個控件屬性值都會被提取出來,并傳遞給數據源控件以執行更新操作。

顯式調用 DataBind 方法
有些控件,如 GridView、FormView 和 DetailsView 控件,當它們通過 DataSourceID 屬性綁定到數據源控件時,會通過隱式調用 DataBind 方法來執行綁定。但是,有些情況需要通過顯式調用 DataBind 方法來執行綁定。
其中一種情況就是使用 DataSource 屬性(而非 DataSourceID 屬性)將某個控件綁定到數據源控件時。在這種情況下,需要顯式調用 DataBind 方法,從而執行數據綁定和解析數據綁定表達式。
另一種情況就是需要手動刷新數據綁定控件中的數據時。假設有這樣一個頁面,其中有兩個控件,這兩個控件都顯示來自同一數據庫的信息(可能使用不同的視圖)。在這種情況下,可能需要顯式地將控件重新綁定到數據,以保持數據顯示的同步。例如,可能有一個顯示產品列表的 GridView 控件,和一個允許用戶編輯單個產品的 DetailsView 控件。雖然 GridView 和 DetailsView 控件所顯示的數據都來自同一數據源,但被綁定到不同的數據源控件,因為這兩個控件使用不同的查詢來獲取其數據。用戶可能會使用 DetailsView 控件更新記錄,從而引發由關聯的數據源控件執行更新。但是,由于 GridView 控件被綁定到不同的數據源控件,所以,該控件仍將顯示舊的記錄值,直至頁面被刷新時才會更新。因此,在 DetailsView 控件更新數據后,可以調用 DataBind 方法。這會使 GridView 控件更新其視圖,并重新執行任何數據綁定表達式以及 <%# 和 %> 分隔符之內的公共范圍代碼。這樣一來,GridView 控件將會反映 DetailsView 控件所做的更新。

使用對查找表的綁定
一種有關數據綁定控件的常見方案是允許用戶使用 DropDownList 控件或其他列表控件從查找表中選擇一個值,以更新或插入該值。在這種情況下,將該查找控件綁定到返回可能值列表的單獨數據源,而將該查找控件的選定值綁定到父數據綁定行中的字段。
可以按照如下方法添加此功能。首先,對于查找控件,向數據綁定控件(例如 GridView、DetailsView 或 FormView 控件)中的模板添加一個列表控件(DropDownList 或 ListBox 控件)。接著將查找控件的 SelectedValue 屬性綁定到容器控件的數據源中的相關字段。其次,將查找控件的 DataSourceID 屬性設置為可檢索查找值的數據源控件。接著將查找控件的 DataTextField 屬性設置為查找表中包含要顯示的值的字段,并將其 DataValueField 屬性設置為查找表中包含查找值的唯一標識符的字段(如果適用)。
下面的代碼示例演示一個 DropDownList 控件,此控件包括在 FormView 控件的 InsertItemTemplate 模板中(它也可以是包括在 DetailsView 控件的 Fields 屬性或 GridView 控件的 Columns 屬性中的 TemplateField 的 InsertItemTemplate 模板)。DropDownList 控件的 SelectedValue 屬性使用 Bind 方法實現與 FormView 控件當前行的 CategoryID 字段之間的雙向綁定。將 DropDownList 控件的 DataSourceID 屬性設置為單獨的數據源控件,用于檢索可能的類別名稱和 ID 列表。將 DropDownList 控件的 DataTextField 屬性設置為查找數據源中的 CategoryName 字段,以便顯示可能的類別名稱列表。將 DropDownList 控件的 DataValueField 屬性設置為查找數據源中相關類別名稱的 CategoryID 字段。當用戶從列表中選擇類別名稱時,DropDownList 控件的 SelectedValue 屬性將被設置為選定類別名稱的類別 ID。

“ASP.NET框架中的數據綁定概要與數據綁定表達式的使用方法”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

邮箱| 昭觉县| 襄汾县| 城固县| 磴口县| 保德县| 云梦县| 思南县| 峨眉山市| 大港区| 江北区| 赫章县| 醴陵市| 资中县| 连云港市| 竹北市| 乐陵市| 衡水市| 崇州市| 新源县| 凤阳县| 武隆县| 米泉市| 灵丘县| 马边| 乌拉特中旗| 余江县| 海原县| 东辽县| 佳木斯市| 隆安县| 黄平县| 建水县| 荔浦县| 河南省| 大丰市| 德州市| 安吉县| 庆安县| 大厂| 松潘县|