常用的前臺資料繫結方法
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") %>' 還可以連線多個欄位
相關文章
- Vue 動態資料繫結核心方法Vue
- WPF/C#:資料繫結到方法C#
- 資料繫結
- Vue的資料繫結Vue
- 簡單資料繫結和複雜資料繫結
- Vue props 雙向資料繫結方法Vue
- 資料繫結原理
- LLM大模型: 常用的資料清洗方法總結大模型
- javascript實現資料的雙向繫結(手動繫結)JavaScript
- 第二講、Vue3.x繫結資料、繫結html、繫結屬性、迴圈資料VueHTML
- JS中的雙向資料繫結及Object.defineProperty方法JSObject
- 在WPF中一種較好的繫結Enums資料方法
- oracle資料庫獲取繫結變數的各種方法Oracle資料庫變數
- angularjs中的資料繫結AngularJS
- 資料繫結之謎
- 【Angular-資料繫結】Angular
- 2、理解資料繫結
- Angular | 理解資料繫結Angular
- 【阿不】深入ASP.NET資料繫結(中)—資料雙向繫結機理ASP.NET
- ASPxGridView的資料繫結顯示View
- 【阿不】深入ASP.NET資料繫結(下)—多樣的繫結方式ASP.NET
- Vue資料繫結簡析Vue
- vue資料繫結原始碼Vue原始碼
- Binding(一):資料繫結
- JS雙向資料繫結JS
- SpringMVC資料繫結demoSpringMVC
- Flex 資料繫結備忘Flex
- js前臺如何使用後臺返回的資料JS
- 〈%# 〉與〈%= 〉的區別,顯示資料與繫結資料
- Go常用的資料結構Go資料結構
- python-物件導向(繫結方法與非繫結方法)Python物件
- 前臺提交資料規範
- Laravel前後臺共享資料Laravel
- 淺析vue的雙向資料繫結Vue
- vue中的雙向資料繫結原理Vue
- java 方法呼叫繫結Java
- 類,物件繫結方法物件
- angular1資料繫結例子Angular