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") %>'
还可以连接多个字段
分享到:
相关推荐
总结来说,"easyui-combobox、combotree后台数据数据组装与前台绑定实例" 主要涉及两个部分:后端 C# 数据组装成 JSON 格式,以及前端使用 EasyUI 的 Combobox 和 Combotree 组件进行数据绑定。通过这样的方式,我们...
这里的`Eval("code")`是前台数据绑定表达式,它会根据数据源中的`code`字段值填充`Label`控件的`Text`属性。 对于HTML控件绑定数据,后台获取数据方法通常是通过控件的`ClientID`找到对应的DOM元素,然后通过...
在这个主题中,我们将深入探讨如何在WPF中通过前台代码实现数据绑定,特别是在`ListView`控件中使用数据模板和样式,并应用数据转换。 首先,数据绑定是WPF的核心特性之一,它简化了UI与业务逻辑之间的通信。在WPF...
**Eval()** 和 **DataBinder.Eval()** 是两种常用的数据绑定表达式,用于在ASP.NET中获取数据项的值。它们的主要区别在于,DataBinder.Eval() 提供了更多的灵活性和安全性。 1. **Eval()** 的基本用法: ```html ...
前台绑定是WPF中数据绑定的一种形式,它将控件的属性与数据源的某个字段进行连接,实现数据的双向同步。WPF的数据绑定机制基于MVVM(Model-View-ViewModel)设计模式,通过数据上下文(DataContext)和绑定表达式...
在本示例中,我们关注的是如何利用Ajax从服务器获取以XML(Extensible Markup Language)格式的数据,然后将这些数据绑定到前端的下拉框中,以及实现下拉框之间的联动效果。下面我们将详细探讨这一过程。 首先,XML...
依赖属性(Dependency Property)是WPF中实现数据绑定的关键机制,而双向数据绑定则确保视图和视图模型之间的数据同步。 首先,让我们深入了解**MVVM**。MVVM模式是由John Gosselin在2005年提出的,它鼓励开发人员...
在给定的代码示例中,Repeater控件被用来展示表格数据,包括数据绑定、分页以及操作数据的功能。 1. 数据绑定: - Repeater控件的`ItemTemplate`部分定义了每行数据的显示格式。`(Container.DataItem, "绑定数据源...
在Windows Presentation Foundation(WPF)中,数据绑定是一种强大的机制,它允许开发者将用户界面(UI)元素与数据源关联起来,实现数据的自动更新。本教程将详细讲解如何解析XML文档并将其内容绑定到WPF UI前台,...
`DataBinder.Eval`是一个非常有用的静态方法,可以用来计算后期绑定的数据绑定表达式,并可以选择性地将结果格式化为字符串。这对于在模板列表内的控件中处理数据行和数据字段特别有用。 **示例代码:** ```csharp ...
最后,`Repeater1.DataBind()`方法调用是至关重要的,因为它触发了数据绑定过程,将数据源中的每一条数据映射到`Repeater`的每一个项。 在实际应用中,`ArrayList`可能会被替换为更强大的数据结构,如`List<T>`,`...
绑定服务允许其他组件(如Activity)与服务建立连接,进行数据交换或者控制服务的生命周期。绑定过程包括调用`bindService()`方法,并实现`ServiceConnection`接口: ```java Intent intent = new Intent(this, ...
最后,我们关注**数据封装**和**前台数据绑定**。在现代前端框架中,如Angular、React、Vue,数据绑定是核心特性。它允许将视图(UI)与模型(数据)直接关联,当模型发生变化时,视图会自动更新,反之亦然。例如,...
在***开发中,前台页面...以上内容介绍了几种前台调用后台变量的方法,以及一些相关的技术要点,如数据绑定、类型转换、命名空间、数据库连接和命令对象等,这些知识点都是在实际的***开发过程中经常会遇到和使用到的。
在C#中,我们可以通过后台代码或前台ASP.NET标记来实现数据绑定。以下是一个简单的示例: ```csharp // 后台代码示例 GridView1.DataSource = GetData(); GridView1.DataBind(); ``` `GetData()`方法通常会从...
总结来说,Struts的自动装填和反射自动装填前台数据虽然在概念上类似,都涉及到了数据绑定和对象的属性设置,但它们的实现方式有所不同。Struts依赖于框架内部的机制和约定,而反射则更底层,提供了更多的灵活性,但...
第二种方法则是通过远程调用从服务器获取数据,再将获取到的数据绑定到DataGrid组件上。这种方法通常涉及到Ajax技术,通过JavaScript发送异步请求到服务器,然后获取返回的Json格式数据并将其绑定到DataGrid上显示。...
本文将深入探讨微信小程序的前台循环数据绑定,通过实例解析其工作原理和使用方法。 首先,我们需要了解的是微信小程序的数据绑定语法。在微信小程序的WXML(WeiXin Markup Language)文件中,我们可以通过特殊的...
通过以上步骤,我们可以实现Service与Activity之间的数据绑定,从而实现在后台运行的Service与前台展示的Activity之间的数据交换,确保了应用的正常运行和用户体验。这种方式对于需要持续监控或者处理后台任务的场景...
这通常涉及从数据库或其他数据源获取数据,然后将数据绑定到DropDownList的DataSource属性。在例子中,创建了一个DataTable对象,并将其设置为DataSource,然后通过DataValueField和DataTextField属性分别指定用于...