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