ASP.NET Eval如何进行数据绑定

ASP.NET Eval在数据绑定方面的应用是众所周知的,不过技术在发展,当ASP.NET Eval 1.1变成ASP.NET Eval 2.0的时候,在操作的时候会有什么变化呢?

假设你已经了解ASP.NET Eval 1.1的数据绑定(特别是Container这个局部变量)的机制,这里主要分析ASP.NET Eval 2.0数据绑定做了那些改进。

ASP.NET Eval 2.0 的数据绑定函数Eval()简化掉了ASP.NET Eval 1.1神秘的Container.DataItem,比如数据绑定表达式:

  1. <%# (Container.DataItem as DataRowView)["ProductName"].ToString() %>

ASP.NET Eval 1.1简化为:(去掉了类型指定, Eval通过反射实现,本文不再阐述)

  1. <%# DataBinder.Eval(Container.DataItem, "ProductName").ToString() %>

ASP.NET Eval 2.0又简化为,去掉了Container局部变量:

  1. <%# Eval("ProductName") %>

那么,Page.Eval()又是如何知道"ProductName"是那个数据的属性呢,即Container.DataItem真的消失了吗?

ASP.NET Eval()是Page的父类TemplateControl的方法

TemplateControl.Eval()可以自动计算出Container, 机制就是从一个dataBindingContext:Stack堆栈来获取。

1. 建立DataItem Container 栈:

在Control.DataBind()中,建立,这样可以保证子控件的DataItem Container始终在栈顶。

  1. publicclass Control
  2. {
  3.  protectedvirtualvoid DataBind(bool raiseOnDataBinding)
  4.  {
  5. bool foundDataItem = false;
  6. if (this.IsBindingContainer)
  7. {
  8.  object o = DataBinder.GetDataItem(this, out foundDataItem);
  9.  if (foundDataItem)
  10. Page.PushDataItemContext(o); <-- 将DataItem压入堆栈
  11. }
  12. try
  13. {
  14.  if (raiseOnDataBinding)
  15. OnDataBinding(EventArgs.Empty);
  16.  DataBindChildren(); <-- 绑定子控件
  17. }
  18. finally
  19. {
  20.  if (foundDataItem)
  21. Page.PopDataItemContext(); <-- 将DataItem弹出堆栈
  22. }
  23.  }
  24. }

2. 获取DataItem Container

  1. publicclass Page
  2. {
  3.  publicobject GetDataItem()
  4.  {
  5. ...
  6. returnthis._dataBindingContext.Peek(); <-- 读取堆栈顶部的DataItem Container,就是正在绑定的DataItem  Container
  7.  }
  8. }

3. TemplateControl.Eval()

  1. publicclass TemplateControl
  2. {
  3.  protectedstring Eval (string expression, string format)
  4.  {
  5. return DataBinder.Eval (Page.GetDataItem(), expression, format);
  6.  }
  7. }

结论:

从上面看出Page.Eval()在计算的时候还是引用了Container.DataItem,只不过这个DataItem通过DataItem Container堆栈自动计算出来的。我认为Page.Eval()看似把问题简化了,其实把问题搞得更加神秘。

本文来源:http://developer.51cto.com/art/200909/151121.htm

原文地址:https://www.cnblogs.com/zhangwei595806165/p/2398500.html