ASP.NET2.0 数据绑定函数Eval()的机制
来源:互联网 发布:python写入txt文件 编辑:程序博客网 时间:2024/05/17 09:02
本文假设你已经了解ASP.NET 1.1的数据绑定(特别是Container这个局部变量)的机制,这里主要分析ASP 2.0数据绑定做了那些改进。
ASP.NET 2.0 的数据绑定函数Eval()简化掉了ASP 1.1神秘的Container.DataItem,比如数据绑定表达式:
ASP.NET 1.1简化为:(去掉了类型指定, Eval通过反射实现,本文不再阐述)
ASP.NET 2.0又简化为,去掉了Container局部变量:
那么,Page.Eval()又是如何知道"ProductName"是那个数据的属性呢,即Container.DataItem真的消失了吗?
Eval()是Page的父类TemplateControl的方法
TemplateControl.Eval()可以自动计算出Container, 机制就是从一个dataBindingContext:Stack堆栈来获取。
1. 建立DataItem Container 栈:
在Control.DataBind()中,建立,这样可以保证子控件的DataItem Container始终在栈顶。
2. 获取DataItem Container
3. TemplateControl.Eval()
结论:
从上面看出Page.Eval()在计算的时候还是引用了Container.DataItem,只不过这个DataItem通过DataItem Container堆栈自动计算出来的。我认为Page.Eval()看似把问题简化了,其实把问题搞得更加神秘。
ASP.NET 2.0 的数据绑定函数Eval()简化掉了ASP 1.1神秘的Container.DataItem,比如数据绑定表达式:
<%# (Container.DataItem as DataRowView)["ProductName"].ToString() %> |
ASP.NET 1.1简化为:(去掉了类型指定, Eval通过反射实现,本文不再阐述)
<%# DataBinder.Eval(Container.DataItem, "ProductName").ToString() %> |
ASP.NET 2.0又简化为,去掉了Container局部变量:
<%# Eval("ProductName") %> |
那么,Page.Eval()又是如何知道"ProductName"是那个数据的属性呢,即Container.DataItem真的消失了吗?
Eval()是Page的父类TemplateControl的方法
TemplateControl.Eval()可以自动计算出Container, 机制就是从一个dataBindingContext:Stack堆栈来获取。
1. 建立DataItem Container 栈:
在Control.DataBind()中,建立,这样可以保证子控件的DataItem Container始终在栈顶。
public class Control { protected virtual void DataBind(bool raiseOnDataBinding) { bool foundDataItem = false; if (this.IsBindingContainer) { object o = DataBinder.GetDataItem(this, out foundDataItem); if (foundDataItem) Page.PushDataItemContext(o); <-- 将DataItem压入堆栈 } try { if (raiseOnDataBinding) OnDataBinding(EventArgs.Empty); DataBindChildren(); <-- 绑定子控件 } finally { if (foundDataItem) Page.PopDataItemContext(); <-- 将DataItem弹出堆栈 } } } |
2. 获取DataItem Container
public class Page { public object GetDataItem() { ... return this._dataBindingContext.Peek(); <-- 读取堆栈顶部的DataItem Container,就是正在绑定的DataItem Container } } |
3. TemplateControl.Eval()
public class TemplateControl { protected string Eval (string expression, string format) { return DataBinder.Eval (Page.GetDataItem(), expression, format); } } |
结论:
从上面看出Page.Eval()在计算的时候还是引用了Container.DataItem,只不过这个DataItem通过DataItem Container堆栈自动计算出来的。我认为Page.Eval()看似把问题简化了,其实把问题搞得更加神秘。
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP.NET2.0 数据绑定函数Eval()的机制 (转贴)
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP.NET2.0 数据绑定函数Eval()的机制
- ASP 2.0 数据绑定函数Eval()的机制
- ASP 2.0 数据绑定函数Eval()的机制
- ASP 2.0 数据绑定函数Eval()的机制
- asp.net2.0数据绑定之Eval和Bind区别
- ASP2.0数据绑定函数Eval()的机制
- ASP.Net2.0 数据绑定控件的优越性在哪里?
- ASP.Net2.0 数据绑定控件的优越性
- Asp.Net2.0学习笔记(一):简单的数据绑定
- ASP.Net2.0 数据绑定控件的优越性在哪里?
- asp.net2.0 treeview的用法--绑定数据库数据
- ASP.Net2.0新增的数据绑定控件
- Spring源代码分析(15)---LocalSessionFactoryBean(工厂的工厂)
- 关于图像到16进制相互转换的几个函数
- 例六:发布和订阅消息(数据推送用例)
- 例五:更新数据
- 关于Gal引擎的剧情编辑器
- ASP.NET2.0 数据绑定函数Eval()的机制
- console程序显示彩色文字
- ${pagemodel.topPageNo2}
- Asp.Net Forms验证(自定义、角色提供程序)
- ASP.NET2.0 文本编辑器FCKeditor
- 隐藏进程源代码
- 决定了……
- 分页不能正常跳转的问题
- 源代码统计工具(SourceCounter) 2.0.10.61发布