ASP.NET控件开发基础之实现控件集合属性

开发 后端
ASP.NET控件开发基础之实现控件集合属性是在学习了类型转换器的使用之后,我们继续讨论讨论集合属性的使用,那么对于自定义控件的操作有什么特别的呢?本文就向你介绍相关内容。

集合属性相信大家都很熟悉也很常用,如DropDownList,ListBox等控件

  1. ﹤asp:DropDownList ID="DropDownList1" runat="server"﹥  
  2.             ﹤asp:ListItem﹥测试1﹤/asp:ListItem﹥  
  3.             ﹤asp:ListItem﹥测试2﹤/asp:ListItem﹥  
  4.             ﹤asp:ListItem﹥测试3﹤/asp:ListItem﹥  
  5.         ﹤/asp:DropDownList﹥ 

ASP.NET控件开发基础之实现控件集合属性1.实现集合属性效果

经过前面几篇的学习,相信这一篇看起来已经相对简单了.我们要做的就是,先定义一个复杂属性,然后用迭代语句获取数组数据即可.

如果看过前面几篇就看看下面代码吧,相信看起来很简单,我们模仿一个DropDownList,为其属性添加背景属性,代码如下

先定义一个集合属性,如下

  1. public class DropItem  
  2.    {  
  3.        private string text;  
  4.        private string value;  
  5.        private Color backColor;  
  6.  
  7.        [  
  8.         Category("Behavior"),  
  9.         DefaultValue(""),  
  10.         Description("项文本"),  
  11.         NotifyParentProperty(true),  
  12.         ]  
  13.        public String Text  
  14.        {  
  15.            get 
  16.            {  
  17.                return text;  
  18.            }  
  19.            set 
  20.            {  
  21.                text = value;  
  22.            }  
  23.        }  
  24.  
  25.        [  
  26.        Category("Behavior"),  
  27.        DefaultValue(""),  
  28.        Description("项值"),  
  29.        NotifyParentProperty(true),  
  30.        ]  
  31.        public String Value  
  32.        {  
  33.            get 
  34.            {  
  35.                return value;  
  36.            }  
  37.            set 
  38.            {  
  39.                this.value = value;  
  40.            }  
  41.        }  
  42.  
  43.        [  
  44.        Category("Behavior"),  
  45.        DefaultValue(""),  
  46.        Description("背景颜色"),  
  47.        NotifyParentProperty(true),  
  48.        ]  
  49.        public Color BackColor  
  50.        {  
  51.            get 
  52.            {  
  53.  
  54.                return backColor;  
  55.            }  
  56.            set 
  57.            {  
  58.                backColor = value;  
  59.            }  
  60.        }  
  61.  
  62.    } 

然后自定义一个控件,输出集合属性,如下代码

  1. [ParseChildren(true"DropItemList")]  
  2.   public class DropColor:WebControl  
  3.    {  
  4.       private ArrayList dropItemList;  
  5.  
  6.        [  
  7.        Category("Behavior"),  
  8.        Description("项集合"),  
  9.        DesignerSerializationVisibility(  
  10.            DesignerSerializationVisibility.Content),  
  11.        PersistenceMode(PersistenceMode.InnerDefaultProperty),  
  12.         
  13.        ]  
  14.  
  15.       //定义集合属性  
  16.       public ArrayList DropItemList  
  17.        {  
  18.            get 
  19.            {  
  20.                if (dropItemList == null)  
  21.                {  
  22.                    dropItemList = new ArrayList();  
  23.                }  
  24.                return dropItemList;  
  25.            }  
  26.        }  
  27.  
  28.       //重写标签  
  29.       protected override HtmlTextWriterTag TagKey  
  30.       {  
  31.           get 
  32.           {  
  33.               return HtmlTextWriterTag.Select;  
  34.           }  
  35.       }  
  36.       protected override void RenderContents(HtmlTextWriter writer)  
  37.       {  
  38.           //输出集合属性  
  39.           foreach (DropItem item in dropItemList)  
  40.           {  
  41.               DropItem dr = item as DropItem;  
  42.               if (dropItemList != null && dropItemList.Count ﹥ 0)  
  43.               {  
  44.               //颜色转换  
  45.               WebColorConverter wcc = new WebColorConverter();  
  46.               writer.AddAttribute(HtmlTextWriterAttribute.Value, dr.Value.ToString());  
  47.               writer.AddStyleAttribute(HtmlTextWriterStyle.BackgroundColor, wcc.ConvertToString(dr.BackColor));  
  48.               writer.RenderBeginTag(HtmlTextWriterTag.Option);  
  49.               writer.Write(dr.Text.ToString());  
  50.               writer.RenderEndTag();  
  51.               }  
  52.           }  
  53.           base.RenderContents(writer);  
  54.       }  
  55.    } 

上面代码注意颜色类型之间的转换,以下为HTML代码

  1. ﹤custom:DropColor ID="DropColor1" runat="server" ForeColor="White"﹥  
  2.         ﹤custom:DropItem BackColor="Yellow" Text="黄色" Value="yellow" /﹥  
  3.         ﹤custom:DropItem BackColor="Red" Text="红色" Value="red" /﹥  
  4.         ﹤custom:DropItem BackColor="Blue" Text="蓝色" Value="blue" /﹥  
  5.         ﹤custom:DropItem BackColor="Green" Text="绿色" Value="green" /﹥  
  6.         ﹤custom:DropItem BackColor="Black" Text="黑色" Value="Black" /﹥  
  7.         ﹤/custom:DropColor﹥ 

输出以后的效果如下图

输出以后的效果 

效果还不错吧,而且挺实用的.

ASP.NET控件开发基础之实现控件集合属性2.定义编辑器

大家一般在添加集合属性的时候往往会在.net自带的编辑器中添加数据,这样可以提高效果,不用在HTML视图添加数据.如下图

添加集合属性 

我们也可以为其添加自定义的编辑器,其实我们一直在用.net自带的编辑器,我们称之为 UI编辑器或视图编辑器,如颜色,时间,超级链接等,大家该有所体会

其编辑器的基类为位于System.Drawing.Design命名空间的UITypeEditor,很多UI编辑器都从此类派生,有兴趣的可以去了解下这个类.

你们如何使用使用UI编辑器呢?也跟上一篇讲的类型转换器一样,你先要定义一个UI编辑器,然后与相关属性关联起来.

因为所定义的是一个集合类,而.net已经为我们提供了一个集合编辑器的CollectionEditor类,其已经为我们做了很多工作了,我们最简单的只需重写几个方法即可.具体其他属性和方法请参考MSDN,如下代码

  1. public class DropItemEditor : CollectionEditor  
  2.  {  
  3.      public DropItemEditor(Type type)  
  4.          : base(type)  
  5.      {  
  6.      }  
  7.      //一次可否选择多项  
  8.      protected override bool CanSelectMultipleInstances()  
  9.      {  
  10.          return false;  
  11.      }  
  12.  
  13.      //获取此集合包含的数据类型  
  14.      protected override Type CreateCollectionItemType()  
  15.      {  
  16.          return typeof(DropItem);  
  17.      }  
  18.  } 

然后把集合属性与编辑器关联起来,添加了一个EditorAttribute,第一个参数为指定的编辑器类型,第二个为基本类型

  1.  Category("Behavior"),  
  2.  Description("项集合"),  
  3.  DesignerSerializationVisibility(  
  4.      DesignerSerializationVisibility.Content),  
  5.  PersistenceMode(PersistenceMode.InnerDefaultProperty),  
  6.  Editor(typeof(DropItemEditor), typeof(UITypeEditor)),  
  7.  ]  
  8. //定义集合属性  
  9. public ArrayList DropItemList  
  10.  {  
  11.      get 
  12.      {  
  13.          if (dropItemList == null)  
  14.          {  
  15.              dropItemList = new ArrayList();  
  16.          }  
  17.          return dropItemList;  
  18.      }  
  19.  } 

然后再来看下效果,这样就方面很多了.

效果 

如果还不想看到编辑器里的CustomComponents的命名空间的话,你可以像上一篇一样自定义一个类型转换器,代码如下:

  1. public class DropItemConverter : ExpandableObjectConverter  
  2. {  
  3.     方法#region 方法  
  4.       
  5.     public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType)  
  6.     {  
  7.         if (sourceType == typeof(string))  
  8.         {  
  9.             return true;  
  10.         }  
  11.         return base.CanConvertFrom(context, sourceType);  
  12.     }  
  13.  
  14.     public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType)  
  15.     {  
  16.         if (destinationType == typeof(string))  
  17.         {  
  18.             return true;  
  19.         }  
  20.         return base.CanConvertTo(context, destinationType);  
  21.     }  
  22.  
  23.     public override object ConvertFrom(ITypeDescriptorContext context, CultureInfo culture,  
  24.         object value)  
  25.     {  
  26.         if (value == null)  
  27.         {  
  28.             return new DropItem();  
  29.         }  
  30.         if (value is string)  
  31.         {  
  32.             string s = (string)value;  
  33.             if (s.Length == 0)  
  34.             {  
  35.                 return new DropItem();  
  36.             }  
  37.             return "DropItem";  
  38.  
  39.         }  
  40.         return base.ConvertFrom(context, culture, value);  
  41.     }  
  42.  
  43.     public override object ConvertTo(  
  44.         ITypeDescriptorContext context,  
  45.         CultureInfo culture, object value, Type destinationType)  
  46.     {  
  47.         if (value != null)  
  48.         {  
  49.             if (!(value is DropItem))  
  50.             {  
  51.                 throw new ArgumentException(  
  52.                     "Invalid DropItem""value");  
  53.             }  
  54.         }  
  55.  
  56.         if (destinationType == typeof(string))  
  57.         {  
  58.             if (value == null)  
  59.             {  
  60.                 return String.Empty;  
  61.             }  
  62.             return "DropItem";  
  63.         }  
  64.         return base.ConvertTo(context, culture, value,  
  65.             destinationType);  
  66.     }  
  67.     #endregion  

然后还是照着步骤把属性与其关联起来

  1. [TypeConverter(typeof(DropItemConverter))]  
  2.   public class DropItem  
  3.   {  
  4.   } 

再来看下效果

效果 

好了,这回讲的比较简单又实用,希望对大家有帮助.大家同时也可以参考MSDN里的例子,下面的示例代码下载我也加上了MSDN的例子.
已经写了10篇了,我们应该有些基础了,我想大家该可以做出一些简单实用的控件了.

ASP.NET控件开发基础之实现控件集合属性的相关内容就讲解到这里,希望对你了解ASP.NET控件开发基础之实现控件集合属性有所帮助。

【编辑推荐】

  1. ASP.NET自定义控件属性浅析
  2. ASP.NET控件开发基础之自定义控件样式属性浅析
  3. ASP.NET控件开发基础之复合控件浅析
  4. ASP.NET控件开发基础之复合控件事件处理浅析
  5. ASP.NET控件开发基础之类型转换器浅析
责任编辑:仲衡 来源: 博客园
相关推荐

2009-08-06 10:49:45

ASP.NET服务器控

2009-08-06 18:18:27

ASP.NET控件开发ASP.NET复合控件

2009-08-06 17:52:45

ASP.NET控件开发自定义控件

2009-08-07 13:31:41

ASP.NET控件开发

2009-08-04 10:43:59

ASP.NET控件开发

2009-08-06 09:18:01

ASP.NET自定义控ASP.NET控件开发

2009-08-07 14:42:02

ASP.NET控件开发

2009-08-06 18:32:00

ASP.NET控件开发ASP.NET复合控件

2009-08-07 15:24:16

ASP.NET模板控件

2009-08-06 13:08:23

ASP.NET控件开发

2009-08-06 17:13:56

ASP.NET自定义控

2009-08-07 14:05:21

ASP.NET控件

2009-07-30 16:52:38

复合控件ASP.NET服务器控

2009-08-07 15:34:15

ASP.NET数据绑定

2009-07-28 14:47:18

ASP.NET MVC

2009-08-07 13:56:46

ASP.NET控件开发

2009-07-27 17:25:53

ASP.NET验证控件

2009-07-27 16:19:59

ASP.NET报表控件

2009-08-17 09:24:25

ASP.NET控件

2009-08-03 15:08:00

SqlDataSour
点赞
收藏

51CTO技术栈公众号