Используйте атрибуты ParseChildrenAttribute и PersistChildrenAttribute :
[ParseChildren(false)]
[PersistChildren(true)]
public class MyControl : UserControl { }
Это приведет к тому, что все элементы управления, которые вы поместите в ссылку:
<uc:MyControl runat="server">
<asp:TextBox runat="server" />
<uc:MyControl>
Для добавления в конец коллекции Controls содержимого UserControl.
Однако, если вы хотите иметь набор элементов управления, вам, вероятно, следует использовать серверный элемент управления, а не пользовательский элемент управления. Для элемента управления, который работает следующим образом:
<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; }
}
И коллекция вкладок:
public class TabCollection : Collection<Tab> { }