常用的前台数据绑定方法【个人收集】

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
 
Text='<%# DataBinder.Eval(Container.DataItem, "字段") %>'
这样的方法是最快的

Text='<%# GetPrice() %>'
也可以绑定方法,但方法要是public的

Text='<%# "CarDetails.aspx?CarID=" + DataBinder.Eval(Container.DataItem, "CarID") %>'
还可以连接多个字段
作者:江宁织造
博客:http://www.cnblogs.com/wgx0428/
原文地址:https://www.cnblogs.com/wgx0428/p/2425774.html