使用ParseChildrenAttribute和PersistChildrenAttribute属性:
[ParseChildren(false)]
[PersistChildren(true)]
public class MyControl : UserControl { }
这将导致您放置在参考内部的任何控件:
<uc:MyControl runat="server">
<asp:TextBox runat="server" />
<uc:MyControl>
将此内容附加到您的用户控件内容的 Controls 集合末尾。
但是,如果您想要一个控件集合,您应该使用服务器控件而不是用户控件。对于像这样工作的控件:
<foo:TabControl runat="server">
<Tabs>
<foo:Tab CssClass="myclass" Title="Hello World" />
</Tabs>
</foo:TabControl>
你需要一个Control类,该类具有一个名为Tabs的属性;Tabs属性应该是一个集合,并且应包含类型为Tab的对象。我在这里创建了这三个类:
[ParseChildren(true, "Tabs")]
public class TabControl: WebControl, INamingContainer
{
private TabCollection _tabs;
[DesignerSerializationVisibility(DesignerSerializationVisibility.Content)]
[PersistenceMode(PersistenceMode.InnerDefaultProperty)]
public TabCollection Tabs
{
get
{
if (_tabs == null)
{
_tabs = new TabCollection();
}
return _tabs;
}
}
protected override void Render(HtmlTextWriter writer)
{
foreach (Tab tab in Tabs)
{
writer.WriteBeginTag("div");
writer.WriteAttribute("class", tab.CssClass);
writer.Write(HtmlTextWriter.TagRightChar);
writer.Write("this is a tab called " + tab.Title);
writer.WriteEndTag("div");
}
}
}
还有标签类:
public class Tab
{
public string CssClass { get; set; }
public string Title { get; set; }
}
还有选项卡(tab)集合:
public class TabCollection : Collection<Tab> { }