日期:2012-05-13  浏览次数:20846 次

ASP.NET自定义控件是个很好的模型,可以在网页中象堆积木般构筑软件,可以

使用大量的第三方控件来完成自己不擅长的功能。但自定义控件编写起来有一定难度。

一直以来,如何在ASPX设计时页面中保持子控件的生成代码问题因扰着我。近段研究了

一下微软的IE Webcontrol中的TreeView控件,终于搞清楚了此问题,不敢独享,特将它

总结了一下,并做了个示例工程,放在我网站上(http://www.aspxcontrol.com/blog)供网友

下载。
总结起来,要点如下:
1.将子控件单独定义为类,如public class noteItem{},为了不让此子控件在整个DLL被

拖入工具箱时不显示,可以使用此特性:[ToolboxItem(false)]
2.子控件应为集合类,引用System.Collection ,定义:
public class noteItemCollection:System.Collections.CollectionBase
3.实现成员:
Add(),this[int]。
4.在主类中定义加入特性:
[DesignerSerializationvisibility(DesignerSerializationvisibility.Content)]
[PersistenceMode(PersistenceMode.InnerDefaultProperty)]
[Editor(typeof(CollectionEditor),typeof(UITypeEditor))]
如果实现了自己的编辑器,可将typeof(CollectionEditor)换成自己的,可以是WinForm

的,可参考TreeView源码。
5.在主类中定义一集合变量和一ArrayList变量,如:
private noteItemCollection _notes;
private ArrayList al;
在构造函数内写:
{
al = new ArrayList();
_notes = new noteItemCollection(al);
}
这样,在加了子控件后,就会在ASPX的HTML页面中加入类似:<waki:sample>
<waki:Note>
<waki:item id="1"></waki:item>
<waki:item id="2"></waki:item>
</waki:Note>
</waki:sample>这样的代码了,就可以避免让用户自己输入XML代码了。