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

ASP.NET控件開發基礎之類型轉換器淺析

開發 后端
ASP.NET控件開發基礎之類型轉換器是在一步步的加上元數據(特性)之后,使得設計時效果更加好,如對復雜屬性應用以下特性,使屬性瀏覽器支持擴展/折疊效果,使你更加容易編輯子屬性,但接著我又遇到了問題,所以必須去解決,那么本文ASP.NET控件開發基礎之類型轉換器就向你講述這方面的內容。

ASP.NET控件開發基礎之類型轉換器1.認識默認屬性瀏覽器支持

讓我們再認識一下屬性,大家知道每個屬性都是有類型的,最熟悉就是string,int這些類型了,VS2005屬性瀏覽器對這些屬性類型進行了識別,
如下例子

(1)table控件的Height屬性,當你設置屬性為字符串時,則提示錯誤信息

提示錯誤信息 

(2)當屬性類型為Color屬性時,屬性瀏覽器為你提供顏色選擇器

類型為Color屬性 

(3)當屬性類型為枚舉類型時,屬性瀏覽器則支持下拉框選擇

類型為枚舉類型時 

(4)當類型是時間類型,屬性瀏覽器則支持時間選擇器

類型是時間類型 

通過上面,我們認識到屬性瀏覽器默認會判別屬性類型,當屬性值跟屬性類型不符時,則會提示錯誤信息.這里我們還認識到屬性瀏覽器默認為一些屬性類型提供了便利

ASP.NET控件開發基礎之類型轉換器2.屬性表現形式的多樣性

在定義控件屬性時,可以直接這樣定義,屬性都為字符串形式

  1. ﹤asp:TextBox ID="TextBox1" runat="server"   
  2.         Height="11" BackColor="Blue"   
  3.         ForeColor="#FF8000"﹥測試﹤/asp:TextBox﹥ 

用代碼表示則是這樣,在后臺代碼中定義的屬性類型必須相對應,BackColor必須為Color類型,否則則會出錯,當在頁面呈現時,則以字符串形式呈現.

  1. protected void Page_Load(object sender, EventArgs e)  
  2.  
  3.    //TextBox1.BackColor = "blue";  
  4.    TextBox1.BackColor = System.Drawing.Color.Red;  
  5.    TextBox1.BackColor = System.Drawing.Color.FromName("blue");  

通過上面,我們認識到屬性類型需要轉換,這里便要引出我們所要講的話題,類型轉換器.

例如,當BackColor="Blue" 時,則會激活一個類型轉換器實例將字符串值轉換成聲明的類型(即將"blue"轉換成Color類型,然后賦給BackColor.

.net類庫中的基本類型和許多類型都有與其相關聯的類型轉換器.

一般常用的類型有String,Int,Boolean,DateTime,Enum等類型,其類型已默認與其相對應的類型轉換器關聯起來.

Color類默認關聯的類型轉換器System.Drawing.ColorConverter

FontInto類默認關聯的類型轉換器System.Drawing.FontConverter

類型轉換器的基類為System.ComponentModel.TypeConverter,所有的類型轉換器都從其派生.

下面我們再來看一個例子,

我們先定義一個復雜屬性,用于測試

示例一

  1.  using System;  
  2.  using System.Collections.Generic;  
  3.  using System.Text;  
  4.    
  5.  namespace CustomComponents  
  6. {  
  7.     public class Name  
  8.     {  
  9.         private string firstName;  
  10.         private string lastName;  
  11.         public String FirstName  
  12.         {  
  13.             get 
  14.             {  
  15.                 return firstName;  
  16.             }  
  17.             set 
  18.             {  
  19.                 firstName = value;  
  20.             }  
  21.         }  
  22.  
  23.         public String LastName  
  24.         {  
  25.             get 
  26.            {  
  27.                 return lastName;  
  28.            }  
  29.             set 
  30.             {  
  31.                 lastName = value;  
  32.             }  
  33.        }     
  34.   }  

再看aspx文件

其中我們輸出了Label的幾個屬性,包括FontInfo這個復雜屬性,并且實例化了上面定義的Name類

  1. ﹤%@ Page Language="C#" %﹥  
  2.  
  3. ﹤!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
  4. "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"﹥  
  5.  
  6. ﹤script runat="server"﹥  
  7.  
  8.   void Page_Load(object sender, EventArgs e)  
  9.   {  
  10.     myLabel.Font.Bold = true;  
  11.     myLabel.Font.Italic = false;  
  12.     myLabel.Font.Name = "verdana";  
  13.     myLabel.Font.Overline = false;  
  14.     myLabel.Font.Size = 10;  
  15.     myLabel.Font.Strikeout = false;  
  16.     myLabel.Font.Underline = true;  
  17.     
  18.     Response.Write(myLabel.Font + "﹤br﹥");  
  19.     Response.Write(Label1.Width);  
  20.     Response.Write(Label1.BackColor+"﹤br﹥");  
  21.     Response.Write(Label1.ForeColor + "﹤br﹥");  
  22.  
  23.     CustomComponents.Name n = new CustomComponents.Name();  
  24.     n.FirstName = "張";  
  25.     n.LastName = "三";  
  26.     Response.Write(n);  
  27.   }  
  28.  
  29. ﹤/script﹥  
  30. ﹤html xmlns="http://www.w3.org/1999/xhtml" ﹥  
  31. ﹤head id="Head1" runat="server"﹥  
  32.     ﹤title﹥FontInfo Example﹤/title﹥  
  33. ﹤/head﹥  
  34.   ﹤body﹥  
  35.     ﹤form id="form1" runat="server"﹥  
  36.     ﹤h3﹥FontInfo Example﹤/h3﹥  
  37.       ﹤asp:Label id="myLabel"   
  38.         runat="server" ﹥  
  39.       ﹤/asp:Label﹥  
  40.         ﹤br /﹥  
  41.         ﹤br /﹥  
  42.         ﹤asp:Label ID="Label1" Width="200px" runat="server"   
  43.                     BackColor="#FF8080" Text="Label" ForeColor="Red"﹥  
  44.           ﹤/asp:Label﹥  
  45.     ﹤/form﹥  
  46.   ﹤/body﹥  
  47. ﹤/html﹥ 

下面看看輸出結果,如下圖

輸出結果 

結果是將FontInfo屬性和Color屬性轉換成字符串形式呈現,而我們自定義的Name屬性只以其類型呈現,并未呈現其子屬性值.
再來看看***點默認屬性瀏覽器支持和第五篇我們所定義的一個復雜屬性CustomComponents.Address,
CustomComponents.Address屬性同樣存在著這樣的問題,再對比一下FontInfo屬性在屬性瀏覽器的支持,如下圖

FontInfo屬性 

---------------------------------------------------------------------------

FontInfo屬性 

復雜屬性CustomComponents.Address無法編輯,只讀,而且顯示的是其屬性類型.
復雜屬性Font則默認顯示了子其屬性的值(其默認只顯示Names值和Size值,且為只讀)

問題來了,我們要根據需要為自定義屬性實現類型轉換器.

ASP.NET控件開發基礎之類型轉換器3.自定義屬性類型轉換器

上面已經說明問題所在了,實現類型轉換器,可以將屬性類型和字符串類型之間相互轉換.

下面我們就為解決這個問題而來了解類型轉換器,我們還是以第五篇的那個例子來學習

在說第二點屬性表現形式的多樣性的時候已經說過了

類型轉換器的基類為System.ComponentModel.TypeConverter,所有的類型轉換器都從其派生.

下面以第五篇時的例子為基礎

我們為Address實現了一個類型轉換器,其實現了復雜屬性代碼的折疊,如下代碼

  1. [TypeConverter(typeof(ExpandableObjectConverter))]  
  2.     public class Address  
  3.     {  

System.ComponentModel.ExpandableObjectConverter 類也是從TypeConverter類派生

所以當自定義復雜類型的類型轉換器時,則可從ExpandableObjectConverter 類派生

如果你定義的屬性不是復雜屬性,則可以直接從TypeConverter類派生

(1) 值翻譯的類型轉換器

從TypeConverter類派生的自定義類型轉換器則需要重寫TypeConverter類幾個方法,主要目的就是實現自定義屬性類型與字符串值之間的轉換.

你需要了解以下幾個方法,這里我們就以Address屬性為例子,這樣來解釋以下方法更好理解.

其實可以理解成一來一去的關系,Form,To,相互之間的轉換,如下代碼:

TypeDescriptor類的方法為靜態方法,通過GetConverter方法獲取類型轉換器
然后通過TypeConverter類的ConvertFromString方法和ConvertToString相互轉換類型.

示例二

  1. public class AddressConverter : ExpandableObjectConverter  
  2.    {  
  3.        方法#region 方法  
  4.        // 返回值能否將String類型轉換為Address類型  
  5.        //sourceType表示要轉換的類型  
  6.        public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType)  
  7.        {  
  8.            if (sourceType == typeof(string))  
  9.            {  
  10.                return true;  
  11.            }  
  12.            return base.CanConvertFrom(context, sourceType);  
  13.        }  
  14.  
  15.        // 返回值能否將Address類型轉換為String類型  
  16.        //sourceType表示要轉換到的類型  
  17.        public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType)  
  18.        {  
  19.            if (destinationType == typeof(string))  
  20.            {  
  21.                return true;  
  22.            }  
  23.            return base.CanConvertTo(context, destinationType);  
  24.        }  
  25.  
  26.        //將String類型轉換為Address類型  
  27.        //value為要轉換的類型  
  28.        public override object ConvertFrom(ITypeDescriptorContext context, CultureInfo culture,  
  29.            object value)  
  30.        {  
  31.            if (value == null)  
  32.            {  
  33.                return new Address();  
  34.            }  
  35.  
  36.            if (value is string)  
  37.            {  
  38.                string s = (string)value;  
  39.                if (s.Length == 0)  
  40.                {  
  41.                    return new Address();  
  42.                }  
  43.  
  44.                string[] parts = s.Split(culture.TextInfo.ListSeparator[0]);  
  45.  
  46.                if (parts.Length != 4)  
  47.                {  
  48.                    throw new ArgumentException("Invalid Address""value");  
  49.                }  
  50.                //返回指定類型轉換器  
  51.                TypeConverter stringConverter = TypeDescriptor.GetConverter(typeof(string));  
  52.                return new Address((string)stringConverter.ConvertFromString(context, culture, parts[0]),  
  53.                    (string)stringConverter.ConvertFromString(context, culture, parts[1]),  
  54.                    (string)stringConverter.ConvertFromString(context, culture, parts[2]),  
  55.                    (string)stringConverter.ConvertFromString(context, culture, parts[3]));  
  56.  
  57.            }  
  58.  
  59.  
  60.            return base.ConvertFrom(context, culture, value);  
  61.        }  
  62.  
  63.        //將Address類型轉換為String類型  
  64.        //value為要轉換的類型  
  65.        public override object ConvertTo(  
  66.            ITypeDescriptorContext context,  
  67.            CultureInfo culture, object value, Type destinationType)  
  68.        {  
  69.            if (value != null)  
  70.            {  
  71.                if (!(value is Address))  
  72.                {  
  73.                    throw new ArgumentException(  
  74.                        "Invalid Address""value");  
  75.                }  
  76.            }  
  77.  
  78.            if (destinationType == typeof(string))  
  79.            {  
  80.                if (value == null)  
  81.                {  
  82.                    return String.Empty;  
  83.                }  
  84.  
  85.                Address ad = (Address)value;  
  86.  
  87.                TypeConverter stringConverter = TypeDescriptor.GetConverter(typeof(string));  
  88.                return String.Join(culture.TextInfo.ListSeparator,  
  89.                    new string[] {  
  90.                                     stringConverter.ConvertToString(context, culture, ad.Street),  
  91.                                     stringConverter.ConvertToString(context, culture, ad.City),  
  92.                                     stringConverter.ConvertToString(context, culture, ad.State),  
  93.                                     stringConverter.ConvertToString(context, culture, ad.Zip)  
  94.                                 });  
  95.            }  
  96.            return base.ConvertTo(context, culture, value,  
  97.                destinationType);  
  98.        }  
  99.        #endregion  
  100.  
  101.    } 

自定義好類型轉換器后,要與屬性相關聯起來

  1. [TypeConverter(typeof(AddressConverter))]  
  2. public class Address  
  3. {  
  4.       
  5.     public Address()  
  6.         :  
  7.         this(String.Empty, String.Empty,  
  8.         String.Empty, String.Empty)  
  9.     { }  
  10.  
  11.     public Address(string street, string city,  
  12.         string state, string zip)  
  13.     {  
  14.         this.street = street;  
  15.         this.city = city;  
  16.         this.state = state;  
  17.         this.zip = zip;  
  18.     }  
  19.       .......  

下面來看下效果,如下圖,屬性編輯器顯示的CustomAddress不再顯示其類型了,已將其轉化為字符串形式了,如果你設置CustomAddress可寫的話,就可以直接編輯CustomAddress屬性,但其只有四個子屬性,所以當大于5個時就會出錯,且格式也不可以亂改,一般情況下都設置其只讀.

 

為了在頁面上顯示這個CustomAddress屬性,還需要為Address類重寫一下ToString方法,如下代碼

  1. #region方法  
  2.         public override string ToString()  
  3.         {  
  4.             return ToString(CultureInfo.CurrentCulture);  
  5.         }  
  6.  
  7.         public virtual string ToString(CultureInfo culture)  
  8.         {  
  9.             return TypeDescriptor.GetConverter(typeof(Address)).ConvertToString(null, culture, this);  
  10.         }  
  11.  
  12.         #endregion  

通過上面重寫ToString方法后,輸出的CustomAddress屬性將不再是其類型,而是以字符串形式呈現,以下以
Response.Write方法輸出Custom1.CustomAddress輸出,如下圖

 

上面講了最基本的值翻譯類型轉換器,希望對大家有幫助

(2)向“屬性”窗口提供標準值列表的類型轉換器

像省份這樣的屬性,為了方便用戶填寫,我們往往做成下拉框形式,一個省份里面又有城市,我們往往列出一部分,如果其中數據不符合用戶要求的話,用戶還可以自己輸入,使用類型轉換器轉換器也可以做到這一點.

實現這一效果你需要重寫以下方法,我們添加一個屬性喜歡的游戲的名稱
因為屬性為String類型,可以直接從StringConverter 派生

示例三

  1. public class GameConverter : StringConverter   
  2.  
  3.    {  
  4.        //返回此對象是否支持可以從列表中選取的標準值集  
  5.        public override bool GetStandardValuesSupported(  
  6.                           ITypeDescriptorContext context)  
  7.        {  
  8.            return true;  
  9.        }  
  10.       //返回下拉框集合類  
  11.       public override StandardValuesCollection  
  12.                     GetStandardValues(ITypeDescriptorContext context)  
  13.       {  
  14.           return new StandardValuesCollection(new string[]{"傳奇",   
  15.                                                     "魔獸世界",   
  16.                                                     "龍與地下城"});  
  17.       }  
  18.       //標準值的集合是否為獨占列表  
  19.       //默認為flase,為true則表示無法修改列表值  
  20.       public override bool GetStandardValuesExclusive(  
  21.                           ITypeDescriptorContext context)  
  22.       {  
  23.           return false;  
  24.       }  
  25.    } 

然后與相關屬性關聯起來

  1. [TypeConverter(typeof(GameConverter))]  
  2.         [Description("喜歡的游戲")]  
  3.         public String Game  
  4.         {  
  5.             get 
  6.             {  
  7.                 return game;  
  8.             }  
  9.             set 
  10.             {  
  11.                 game = value;  
  12.             }  
  13.         } 

好了,.下面我們看一下效果,如下圖,你可以選擇下拉框的值,也可以自己手動輸入,跟枚舉類型很相似,但枚舉類型無法自己修改值.

選擇下拉框的值 

這一篇主要介紹了類型轉換器的基本使用,希望對大家有所幫助,在寫的同時我也學到了很多,講的比較基礎,什么時候我懂了可以再補充,水平有限呀.這一篇就寫到這里,很高興,我已經寫到第9篇了,我會繼續寫下去的,也希望大家喜歡.

ASP.NET控件開發基礎之類型轉換器的相關內容就向你介紹到這里,希望對你了解ASP.NET控件開發基礎之類型轉換器有所幫助。

【編輯推薦】

  1. ASP.NET控件開發基礎之RenderContents使用淺析
  2. ASP.NET自定義控件屬性淺析
  3. ASP.NET控件開發基礎之自定義控件樣式屬性淺析
  4. ASP.NET控件開發基礎之復合控件淺析
  5. ASP.NET控件開發基礎之復合控件事件處理淺析
責任編輯:仲衡 來源: 博客園
相關推薦

2009-08-06 18:18:27

ASP.NET控件開發ASP.NET復合控件

2009-08-07 15:24:16

ASP.NET模板控件

2009-08-06 13:08:23

ASP.NET控件開發

2009-08-07 17:49:44

控件設計器

2009-08-04 14:56:34

ASP.NET數據類型

2009-08-06 09:18:01

ASP.NET自定義控ASP.NET控件開發

2009-08-07 15:34:15

ASP.NET數據綁定

2009-07-27 17:25:53

ASP.NET驗證控件

2009-08-06 18:32:00

ASP.NET控件開發ASP.NET復合控件

2009-08-06 15:21:45

ASP.NET控件開發RenderConte

2009-08-05 17:11:51

ASP.NET控件開發ASP.NET服務器控

2009-08-03 18:00:00

ASP.NET服務器控

2009-07-28 09:32:41

ASP.NET自定義控

2009-08-06 17:52:45

ASP.NET控件開發自定義控件

2009-08-10 14:25:33

ASP.NET服務器控

2009-08-07 14:05:21

ASP.NET控件

2009-08-06 10:49:45

ASP.NET服務器控

2009-08-05 18:46:21

ComboBox顯示ASP.NET控件開發

2009-07-24 09:57:25

ASP.NET HTM

2009-08-07 16:32:52

ASP.NET控件設計時支
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲精品粉嫩美女一区 | 日本一区精品 | 国产视频精品免费 | av免费网站在线 | 亚洲综合视频 | 一级欧美| 久久久91精品国产一区二区三区 | 日韩在线不卡视频 | 男女视频免费 | 亚洲国产精品一区二区三区 | 91久久精品国产91久久 | 亚洲精品视频免费 | 日韩免费 | 九九热最新地址 | av在线一区二区三区 | 久草欧美| 成人在线播放 | 91干b| 91n成人| 久久国产精品一区二区三区 | 日韩一区二区三区视频在线播放 | www.中文字幕.com | 久久亚洲精品久久国产一区二区 | 麻豆av一区二区三区久久 | 久久久久国产一级毛片 | 亚洲国产精品视频一区 | 婷婷狠狠| 久久久日韩精品一区二区三区 | 欧美aⅴ| 亚洲精品日韩综合观看成人91 | www.国产日本 | 日韩欧美在线观看 | www日| 日韩高清电影 | 久久久精品影院 | 日韩三极 | 日韩欧美久久精品 | 欧洲一级毛片 | 99精品免费久久久久久日本 | 欧美午夜精品久久久久久浪潮 | 久久久久久91 |