`

数据绑定以及Container.DataItem的具体分析

阅读更多

http://blog.sina.com.cn/s/print_4a5e327701000b50.html(转)

数据绑定以及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")有什么区别?


DataBinder是System.Web里面的一个静态类,它提供了Eval方法用于简化数据绑定表达式的编写,但是它使用的方式是通过 Reflection等开销比较大的方法来达到易用性,因此其性能并不是最好的。而Container则根本不是任何一个静态的对象或方法,它是 ASP.NET页面编译器在数据绑定事件处理程序内部声明的局部变量,其类型是可以进行数据绑定的控件的数据容器类型(如在Repeater内部的数据绑定容器叫RepeaterItem),在这些容器类中基本都有DataItem属性,因此你可以写Container.DataItem,这个属性返回的是你正在被绑定的数据源中的那个数据项。如果你的数据源是DataTable,则这个数据项的类型实际是DataRowView

分享到:
评论

相关推荐

    DataBinder.Eval总结

    在绑定数据时经常会用到这个句程序:&lt;%# DataBinder.Eval(Container.DataItem,"xxxx")%&gt;或者&lt;%# DataBinder.Eval(Container,"DataItem.xxxx")%&gt; 今天又学到一种,而且微软也说这种方法的效率要比以上两种高。 (...

    深入理解Asp.net中DataBinder.Eval的用法总结

    &lt;&#37;# Bind(“Subject”) %&gt; //绑定字段&lt;&#37;# Container.DataItemIndex + 1%&gt; //实现自动编号&lt;&#37;# DataBinder.Eval&#40;Container.DataItem, “[n]”...# DataBinder.Eval(Container, “DataItem.Colum

    ASP.NET完全入门

    ASP.NET 2.0改善了模板中的数据绑定操作,把v1.x中的数据绑定语法DataBinder.Eval(Container.DataItem, fieldname)简化为Eval(fieldname)。Eval方法与DataBinder.Eval一样可以接受一个可选的格式化字符串参数。缩短...

    ASP.NET Eval进行数据绑定的方法

    简化掉了ASP.NET Eval 1.1神秘的Container.DataItem,比如数据绑定表达式: 代码如下:&lt;&#37;# (Container.DataItem as DataRowView)[“ProductName”].ToString() %&gt;ASP.NET Eval 1.1简化为:(去掉了类型指定, Eval...

    ASP.NET Eval 求值运算的一些用法

    Container.DataItem, “[n]”&#41; %&gt; 通常使用的方法(这三个性能最好) &lt;&#37;# DataBinder.Eval&#40;Container.DataItem, “ColumnName”&#41; %&gt; &lt;&#37;# DataBinder.Eval&#40;Container.DataItem, “Column...

    DataList绑定到Row[]行集合的问题的方法

    Container.DataItem,”fldName”&#41; %&gt;时,编译时将会出现 “DataBinder.Eval:“System.Data.DataRow”不包含名称为 fldName 的属性” 的错误 解决办法:将 &lt;&#37;# DataBinder.Eval&#40;Container....

    C#自定义分页控件

    &lt;td&gt;&lt;%# DataBinder.Eval(Container.DataItem,"unitsinstock")%&gt; ; LEFT: 256px; POSITION: absolute; TOP: 40px" runat="server" Width="500px" FirstPageText="首页" LastPageText="尾页" NextPageText=...

    ASP.NET程序中常用的三十三种代码.txt

     &lt; %# DataBinder.Eval(Container.DataItem, "数据字段1")%&gt;’ & name=’&lt;% # DataBinder.Eval(Container.DataItem, "数据字段2")%&gt;’ /&gt;  7.表格点击改变颜色 if (e.Item.ItemType == ListItemType.Item ||e....

    Ext Js权威指南(.zip.001

    7.3.4 格式化提交数据:ext.data.writer.writer、ext.data.writer.json和ext.data. writer.xml / 322 7.3.5 writer对象的配置项 / 325 7.4 数据模型 / 326 7.4.1 概述 / 326 7.4.2 数据类型及排序类型:ext....

    。NET经典技术

    Container, "DataItem.PriceMoney","{0:F2}"&#41; %&gt;  10.提取动态网页内容  Uri uri = new Uri("http://www.webjx.com/");  WebRequest req = WebRequest.Create(uri);  WebResponse resp = req.GetResponse...

    Repeater绑定dictionary数据源代码及报错解决

    .aspx页面代码 代码如下: ”...# ((KeyValuePair&lt;int&gt;&gt;)Container.DataItem).Key %&gt; ”Repeater2″ runat=”server” xss=removed&gt;&gt;)Container.DataItem).Value %&gt;’&gt; &lt;ItemTemplate&gt; &lt;&#37;# (Container.

    C#(ASP.NET)DateTime日期类型格式化显示

    DataBinder.Eval(Container.DataItem,"starttime","{0:yyyy-M}") 7.显示时间所有部分,包括:年月日时分秒 &lt;asp:BoundColumn DataField="收款时间" HeaderText="收款时间" DataFormatString="{0:yyyy-MM-dd HH24:mm...

    ASP.NET常用代码

    id='&lt;%# DataBinder.Eval(Container.DataItem, "数据字段1")%&gt;' & name='&lt;%# DataBinder.Eval(Container.DataItem, "数据字段2")%&gt;' /&gt; 7.表格点击改变颜色 if (e.Item.ItemType == ListItemType.Item ||e.Item....

    ASP.Net前台调用后台变量的方法

    %# Container.DataItem(“tit”) %&gt; &lt; %= %&gt;: 在程序执行时被调用,可以显示后台变量值 如: *.aspx中: &lt; %= aaa %&gt; *.cs中: protected string aaa=”姓名”; &lt; % %&gt;: 内联代码块里面可以在页面文件*.aspx...

    Asp.net中时间格式化的6种方法详细总结

    1. 数据控件绑定时格式化日期方法: 代码如下: &lt;asp DataField=”AddTime” HeaderText=”添加时间” DataFormatString=”{0:yyyy-... 用DataBinder.Eval进行数据绑定时: 代码如下: DataBinder.Eval(Container.DataItem

    ASP.NET考研资讯网实验报告 含关键代码及注释、关键设置截图

    Container.DataItem,"num"&#41; %&gt;' Text='&lt;%# DataBinder.Eval&#40;Container.DataItem,"name"&#41; %&gt;'&gt; 后台cs文件中的代码: public static string Strs = "";//Strs是用来标记是否需要检索的...

    使用element-ui +Vue 解决 table 里包含表单验证的问题

    这个校验中,最关键的问题在于如何给el-form-item 动态绑定prop。 :prop=”‘tableData.’ + scope.$index + ‘.字段名'” 方法一: &lt;div class=app-container&gt; &lt;el model=fromData ref=from&gt; &lt;el data=from...

    ExtAspNet_v2.3.2_dll

    -不绑定任何数据到Grid时,确保页面不会出错。 -修正了Grid列属性DataFormatString的一个bug,比如设置{0:yy-MM-dd HH:mm}时没有效果。 -修正下拉列表控件不能绑定DataTable的BUG(feedback:RedOcean)。 -增加...

    ExtAspNet v2.2.1 (2009-4-1) 值得一看

    -为TreeNode增加AutoPostBack属性,增加事件数据类TreeCheckEventArgs,为Tree增加事件NodeCheck。 -示例在:http://extasp.net/data/tree_run.aspx -Grid增加GetNoSelectionAlertInParentReference函数,用来...

Global site tag (gtag.js) - Google Analytics