ParseChildrenAttribute属性とPersistChildrenAttribute属性を使用します。
[ParseChildren(false)]
[PersistChildren(true)]
public class MyControl : UserControl { }
これにより、参照内に配置したコントロールが発生します。
<uc:MyControl runat="server">
<asp:TextBox runat="server" />
<uc:MyControl>
UserControl コンテンツの Controls コレクションの末尾に追加します。
ただし、コントロールのコレクションが必要な場合は、ユーザー コントロールではなくサーバー コントロールを使用する必要があります。次のように機能するコントロールの場合:
<foo:TabControl runat="server">
<Tabs>
<foo:Tab CssClass="myclass" Title="Hello World" />
</Tabs>
</foo:TabControl>
Tabs プロパティを持つ Control クラスが必要です。Tabs プロパティは Collection である必要があります。また、Tab 型のオブジェクトが含まれている必要があります。ここに 3 つのクラスを作成しました。
[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> { }