轉帖|其它|編輯:郝浩|2011-03-01 13:42:07.000|閱讀 517 次
概述:ASP.NET Eval在數據綁定方面的應用是眾所周知的,不過技術在發展,當ASP.NET Eval 1.1變成ASP.NET Eval 2.0的時候,在操作的時候會有什么變化呢?假設你已經了解ASP.NET Eval 1.1的數據綁定(特別是Container這個局部變量)的機制,這里主要分析ASP.NET Eval 2.0數據綁定做了那些改進。
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
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
ublic class Page {
public object GetDataItem()
{ ... return this._dataBindingContext.Peek();
<-- 讀取堆棧頂部的DataItem Container,就是正在綁定的DataItem Container
}
}
p 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()看似把問題簡化了,其實把問題搞得更加神秘。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn
文章轉載自:網絡轉載