关于ASP.NET自定义控件中子控件的HTML代码保持(原创)

王朝asp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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代码了。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航