自定义控件(可以动态加载用户控件)
自定义控件(可以动态加载用户控件) 自定义控件中动态加载用户控件
自己写个自定义控件,如
<MyControls:Containers id='myc' runat='server'>
<ITEMPLATE>
<MyControls:MidArea runat='server'>
</MyControls:MidArea>
</ITEMPLATE>
</MyControls:Containers>
要想每次使用Containers时就自动有页眉和页脚,一种方法就是在在做Containers的时候自己在里面加html元素。但是这中方法麻烦,也不容
易便于以后的修改。所以就把页眉和页脚分别做成两个用户控件:Header.ascx,Footer.ascx。这样再在Containers里动态加载他们。
Containers的代码:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace WebComponents
{
/// <summary>
/// Containers自定义控件
/// </summary>
[ParseChildren(true)]//可以创建子控件
public class Containers : Control,INamingContainer
{
public Containers()
{
}
private ITemplate itemTemPlate;
[TemplateContainer(typeof(Containers))]
public ITemplate ItemPlate//项模板
{
get{return itemTemPlate;}
set{itemTemPlate=value;}
}
protected override void CreateChildControls()
{
this.Controls.Clear();
Control Header=Page.LoadControl('Header.ascx');//动态加载Header.ascx,也可判断何时加载
Controls.Add(Header);
Control Footer=Page.LoadControl('Footer.ascx');
Controls.Add(Footer);
}
}
}
这样你在Header.ascx,Footer.ascx里设置好内容就可以使用。当然也可以缓存起来