ASP.NET Eval如何進行數據綁定

來源: IT PUB  發布時間: 2011-02-16 22:49  閱讀: 3468 次  推薦: 0   原文鏈接   [收藏]  
摘要:ASP.NET Eval在數據綁定方面的應用是眾所周知的,不過技術在發展,當ASP.NET Eval 1.1變成ASP.NET Eval 2.0的時候,在操作的時候會有什么變化呢?

  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,比如數據綁定表達式:

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

  ASP.NET Eval 1.1簡化為:(去掉了類型指定, Eval通過反射實現,本文不再闡述)

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

  ASP.NET Eval 2.0又簡化為,去掉了Container局部變量:

 
%# Eval("ProductName") %

  那么,Page.Eval()又是如何知道"ProductName"是那個數據的屬性呢,即Container.DataItem真的消失了嗎?

  ASP.NET 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()看似把問題簡化了,其實把問題搞得更加神秘。

0
0
 
 
 

文章列表

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()