成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

實例:ASP.NET Eval如何撰寫數據庫綁定表達式

開發 后端
本文主要介紹了ASP.NET Eval在數據庫綁定方面的具體應用實例,很典型,希望能在一定程度上為大家的開發道路提供一些幫助。

ASP.NET Eval可以用于數據庫綁定,不過,具體操作似乎比較繁瑣,下面我們就來介紹一種關于ASP.NET Eval幫助撰寫數據庫綁定表達式的方法。

實際上ASP.NET Eval方法是TemplateControl的,而System.Web.UI.Page和System.Web.UI.UserControl都繼承于TemplateControl,所以我們可以在Page和UserControl上直接調用個方法。  
   
Page.Eval方法可以幫助我們更好的撰寫數據綁定表達式,在ASP.NET Eval 1.x時代,數據綁定表達式的一般形式是:

  1. <%# DataBinder.Eval(Container,“DataItem.Name”)   %> 

而在ASP.NET Eval  2.0中,同樣的代碼,我們可以這樣寫:

  1. <%# Eval(“Name”)%>  

ASP.NET Eval  2.0是怎么實現的呢?我們先從Eval方法來研究,通過反射.NET  fromwork   2.0類庫的源代碼,我們可以看到這個方法是這樣實現的:

  1. protected   internal   object   Eval(string   expression)     
  2. {     
  3.      this.CheckPageExists();     
  4.      return   DataBinder.Eval(this.Page.GetDataItem(),   expression);     
  5. }  

第一行我們不必管,這是檢查調用的時候有沒有Page對象的,如果沒有則會拋出一個異常。   關鍵是第二行:

  1. return   DataBinder.Eval(this.Page.GetDataItem(),   expression);  

Page.GetDataItem()也是2.0中新增的一個方法,用途是正是取代ASP.NET Eval  1.x中的Container.DataItem。  

看來不摸清楚GetDataItem()方法,我們也很難明白ASP.NET Eval的原理。GetDataItem的實現也很簡單:

  1. public   object   GetDataItem()     
  2. {     
  3.      if   ((this._dataBindingContext ==  null) || (this._dataBindingContext.Count == 0))     
  4.      {     
  5.            throw   new   InvalidOperationException(SR.GetString("Page_MissingDataBindingContext"));     
  6.      }     
  7.      return   this._dataBindingContext.Peek();     

我們注意到了有一個內部對象_dataBindingContext,通過查源代碼發現這是一個Stack類型的東西。所以他有Peek方法。而這一段代碼很容易看懂,先判斷這個Stack是否被實例化,然后,判斷這個Stack里面是不是有任何元素,如果Stack沒有被實例化或者沒有元素則拋出一個異常。最后是將這個堆棧頂部的元素返回。

ASP.NET Eval  2.0用了一個Stack來保存所謂的DataItem,我們很快就查到了為這個堆棧壓元素和彈出元素的方法:Control.DataBind方法:

  1. protected   virtual   void   DataBind(bool   raiseOnDataBinding)     
  2. {     
  3.       bool   flag1   =   false;//這個標志的用處在上下文中很容易推出來,如果有DataItem壓棧,則在后面出棧。     
  4.        if(this.IsBindingContainer)//判斷控件是不是數據綁定容器,實際上就是判斷控件類是不是實現了INamingContainer     
  5.       {     
  6.           bool   flag2;     
  7.           object   obj1   =   DataBinder.GetDataItem(this,   out   flag2);//這個方法是判斷控件是不是有DataItem屬性,并把它取出來。     
  8.            if   (flag2   &&   (this.Page   !=   null))//如果控件有DataItem     
  9.          {     
  10.             this.Page.PushDataBindingContext(obj1);//把DataItem壓棧,PushDataBindingContext就是調用_dataBindingContext的Push方法     
  11.               flag1   =   true;     
  12.          }     
  13.       }     
  14.       try     
  15.       {     
  16.           if   (raiseOnDataBinding)//這里是判斷是不是觸發DataBinding事件的。     
  17.            {     
  18.              this.OnDataBinding(EventArgs.Empty);     
  19.           }     
  20.          this.DataBindChildren();//對子控件進行數據綁定,如果這個控件有DataItem,則上面會將DataItem壓入棧頂,這樣,在子控件里面調用Eval或者GetDataItem方法,就會把剛剛壓進去的DataItem給取出來。     
  21.       }     
  22.      finally     
  23.      {     
  24.          if(flag1)//如果剛才有壓棧,則現在彈出來。     
  25.           {     
  26.             this.Page.PopDataBindingContext();//PopDataBindingContext就是調用_dataBindingContext的Pop方法     
  27.           }     
  28.      }     
  29.   }     

至此,我們已經可以完全了解ASP.NET Eval  2.0中GetDataIten和Eval方法運作的原理了

關于效率:

毋庸置疑的是強類型轉換Container的效率是最高的,ASP.NET Eval最終是調用DataBinder.Eval方法,DataBinder.Eval是采用反射來獲取數據的,這顯然不如強類型數據轉換。  

我們可以比較一下各種方法:

  1. ((Type)   Container.DataItem).Property  

這種方法效率是最高的,因為不存在任何反射。

其次是:

  1. ((Type)   GetDataItem()).Property 

這種方法效率差的原因在于多了一個Stack的Peek操作,當然,實際上這點兒差別可以忽略。

最后是:ASP.NET Eval或者DataBinder.Eval,這兩種方法都使用反射來查找屬性或者索引器成員,效率大打折扣。  

另外一個值得注意的問題是,所有實現了INamingContainer接口的Control,都應該實現IDataItemContainer接口,因為在Control.DataBind的時候,如果發現控件實現了INamingContainer接口,就會試圖去尋找它的DataItem,如果這個控件沒有實現IDataItemContainer,則DataBinder.GetDataItem方法會使用反射看看控件有沒有一個叫做DataItem的屬性成員,顯然這不是我們希望看到的。  

其實ASP.NET Eval還有一個標記接口:INonBindingContainer,實現了INamingContainer接口的控件可以選擇同時實現這個來命令ASP.NET Eval不去尋找DataItem,可是很可惜,不知道微軟出于什么目的,這個接口是internal的……  

其實效率方面不必太重視了,ASP.NET Eval表達式很好看的,即使有那么極端的重視效率,GeDataItem也是不錯的選擇。毋庸置疑的是強類型轉換Container的效率是最高的,Eval最終是調用DataBinder.Eval方法,DataBinder.Eval是采用反射來獲取數據的,這顯然不如強類型數據轉換。

本文來自博客園   作者:佚名

【編輯推薦】

  1. ASP.NET中Bind和Eval的區別:兩種綁定
  2. ASP.NET的XML數據
  3. ASP.NET模板控件開發淺析
  4. ASP.NET 4.0新特性ClientID的改進
  5. ASP.NET數據綁定的內部機理淺析
責任編輯:林琳 來源: 博客園
相關推薦

2009-07-21 17:46:47

ASP.NET表達式

2009-09-10 23:17:33

ASP.NET Eva

2009-07-29 09:12:31

ASP.NET數據庫連

2009-08-31 16:39:32

ASP.NET表達式樹

2009-02-23 15:20:03

SQL Server數據庫ASP.NET

2009-07-31 09:57:47

ASP.NET數據庫緩

2009-07-28 14:06:28

ASP.NET 2.0

2009-07-22 17:21:27

ASP.NET 2.0

2009-07-28 17:36:21

ASP.NET數據庫連

2009-08-07 15:34:15

ASP.NET數據綁定

2009-07-30 15:09:44

asp.net中Bin

2009-08-05 15:40:49

ASP.NET連接數據

2009-08-11 12:52:05

ASP.NET數據庫程

2009-08-03 18:15:05

ASP.NET數據綁定

2009-07-27 17:58:10

ASP.NET數據庫編

2010-05-25 08:49:33

連接MySQL

2009-09-13 22:35:12

ASP.NET數據庫

2009-08-07 15:45:26

ASP.NET復合控件數據綁定

2009-08-05 17:43:48

ASP.NET 2.0

2009-08-05 17:26:25

ASP.NET 2.0
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲成人免费 | 五月综合激情在线 | 一级黄色片一级黄色片 | 欧美日本在线观看 | 在线免费av观看 | 日本一区二区三区四区 | 中文字幕一区在线 | 日韩欧美二区 | 国产精品国产三级国产aⅴ无密码 | 99久久婷婷国产综合精品 | 欧美日韩久久 | 日韩精品一区在线 | 国产在线一区二区 | 欧美成年视频 | 欧美aaa一级片 | 欧美成人精品一区二区男人看 | 久久亚洲精品久久国产一区二区 | av免费观看在线 | 午夜精品久久久久久久 | 91精品国产91久久久久久密臀 | 亚洲入口 | 无人区国产成人久久三区 | 亚洲精品第一页 | 综合婷婷 | 国产精品一区在线 | 精品免费国产一区二区三区四区介绍 | 成人免费视频一区 | 亚洲精品美女视频 | 午夜视频在线播放 | 亚洲一区欧美一区 | 97超碰站 | 久久天天躁狠狠躁夜夜躁2014 | 日韩精品成人 | 亚洲一区中文 | 九色在线观看 | 第四色影音先锋 | 亚洲成人久久久 | 97天天干 | 亚洲欧美综合 | 久久一区 | av在线播放国产 |