資料繫結以及Container.DataItem的具體分析
靈活的運用資料繫結操作
繫結到簡單屬性:<%#UserName%>
繫結到集合:<asp:ListBox id="ListBox1" 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。對於它我還需要進一步理解。
初學.NET,現在在看DataGrid控制元件,在ItemTemplate顯示資料時,
DataBinder.Eval(Container.DataItem,"Name")和Container.DataItem("Name")有什麼區別?
<asp:Label ID="lblType" runat="server" Text='<%# Eval("BangType").ToString().Replace("重車","") %>'></asp:Label>
DataBinder是System.Web裡面的一個靜態類,它提供了Eval方法用於簡化資料繫結表示式的編寫,但是它使用的方式是通過 Reflection等開銷比較大的方法來達到易用性,因此其效能並不是最好的。而Container則根本不是任何一個靜態的物件或方法,它是 ASP.NET頁面編譯器在資料繫結事件處理程式內部宣告的區域性變數,其型別是可以進行資料繫結的控制元件的資料容器型別(如在Repeater內部的資料繫結容器叫RepeaterItem),在這些容器類中基本都有DataItem屬性,因此你可以寫Container.DataItem,這個屬性返回的是你正在被繫結的資料來源中的那個資料項。如果你的資料來源是DataTable,則這個資料項的型別實際是DataRowView
資料繫結以及Container.DataItem的具體分析
相關文章
- Vue 雙向資料繫結原理分析Vue
- 原始碼分析:Vue的雙向資料繫結原始碼Vue
- vue.js原始碼- 剖析observer,dep,watch如何具體的實現資料雙向繫結Vue.js原始碼Server
- 資料繫結
- UWP中新加的資料繫結方式x:Bind分析總結
- Vue的資料繫結Vue
- 簡單資料繫結和複雜資料繫結
- SAP UI5 資料繫結語法裡的特殊符號,以及絕對繫結和相對繫結概念詳解UI符號
- 具體問題具體分析
- 搞懂:MVVM模型以及VUE中的資料繫結資料劫持釋出訂閱模式MVVM模型Vue模式
- 資料繫結原理
- silverlight中Combox繫結資料以及動態繫結預設選定項的用法
- javascript實現資料的雙向繫結(手動繫結)JavaScript
- 第二講、Vue3.x繫結資料、繫結html、繫結屬性、迴圈資料VueHTML
- 淺談Vue中的資料繫結的實現,以及Vue3.0的proxyVue
- angularjs中的資料繫結AngularJS
- 資料繫結之謎
- 【Angular-資料繫結】Angular
- 2、理解資料繫結
- Angular | 理解資料繫結Angular
- 單連結串列實現原理以及具體程式碼(java)Java
- 【阿不】深入ASP.NET資料繫結(中)—資料雙向繫結機理ASP.NET
- ASPxGridView的資料繫結顯示View
- 常用的前臺資料繫結方法
- 【阿不】深入ASP.NET資料繫結(下)—多樣的繫結方式ASP.NET
- Vue資料繫結簡析Vue
- vue資料繫結原始碼Vue原始碼
- Binding(一):資料繫結
- JS雙向資料繫結JS
- SpringMVC資料繫結demoSpringMVC
- Flex 資料繫結備忘Flex
- 〈%# 〉與〈%= 〉的區別,顯示資料與繫結資料
- 大資料具體是幹什麼的大資料
- 淺析vue的雙向資料繫結Vue
- vue中的雙向資料繫結原理Vue
- “new” 都做了些啥以及this繫結?
- angular1資料繫結例子Angular
- Vue資料雙向繫結原理Vue