Как я могу создать собственный Repeater, который отображает верхний и нижний колонтитулы на основе свойств? - PullRequest
7 голосов
/ 17 сентября 2010

Я хочу создать Repeater, который отображает верхний / нижний колонтитул на основе свойств, только если DataSource пуст.

public class Repeater : System.Web.UI.WebControls.Repeater
{
    public bool ShowHeaderOnEmpty { get; set; }
    public bool ShowFooterOnEmpty { get; set; }

    [DefaultValue((string)null),
    PersistenceMode(PersistenceMode.InnerProperty),
    TemplateContainer(typeof(System.Web.UI.WebControls.RepeaterItem)),
    Browsable(false)]
    public ITemplate EmptyTemplate { get; set; }
}

Я также хочу создать EmptyTemplate, если DataSource пусто показать этот шаблон ...

Я понятия не имею, как это реализовать.Что я должен переопределить для достижения этого поведения?

Ответы [ 5 ]

4 голосов
/ 26 сентября 2010
[ToolboxData("<{0}:SmartRepeater runat=\"server\"></{0}:SmartRepeater>")]
public partial class SmartRepeater : Repeater
{
    public bool ShowHeaderOnEmpty { get; set; }
    public bool ShowFooterOnEmpty { get; set; }

    private ITemplate emptyTemplate = null;

    [PersistenceMode(PersistenceMode.InnerProperty)]
    public ITemplate EmptyTemplate
    {
        get { return this.emptyTemplate; }
        set { this.emptyTemplate = value; }
    }

    protected override void OnDataBinding(EventArgs e)
    {
        base.OnDataBinding(e);
        if (this.Items.Count == 0)
        {
            this.Controls.Clear();

            if (this.HeaderTemplate != null && ShowHeaderOnEmpty)
                this.HeaderTemplate.InstantiateIn(this);

            if (this.EmptyTemplate!=null)
                this.EmptyTemplate.InstantiateIn(this);

            if (this.FooterTemplate != null && ShowFooterOnEmpty)
                this.FooterTemplate.InstantiateIn(this);
        }
    }
}

Использование:

<UC:SmartRepeater ID="rep" runat="server" ShowHeaderOnEmpty="true" ShowFooterOnEmpty="true">
    <HeaderTemplate>HEADER</HeaderTemplate>
    <ItemTemplate>Item</ItemTemplate>
    <SeparatorTemplate>, </SeparatorTemplate>
    <EmptyTemplate><b>Nothing</b></EmptyTemplate>
    <FooterTemplate>FOOTER</FooterTemplate>
</UC:SmartRepeater>
2 голосов
/ 20 сентября 2010

Используйте ListView вместо Repeater.Он уже содержит элементы EmptyDataTemplate и EmptyItemTemplate, поэтому вам не нужно ничего делать:)

0 голосов
/ 21 сентября 2010

переопределяет событие рендера для вывода необходимого HTML-кода на основе всех свойств, которые вы упомянули.

0 голосов
/ 18 сентября 2010

Если вы хотите сделать это только с помощью ретранслятора, вы можете сделать это:

    <asp:Repeater runat="server" OnItemDataBound="ShowHideHeaderFooter">
    <HeaderTemplate>
        <asp:PlaceHolder runat="server" ID="PlaceHolderHeader">
            HEADER STUFF
        </asp:PlaceHolder>
    </HeaderTemplate>
    <ItemTemplate>
        ITEM STUFF
    </ItemTemplate>
    <FooterTemplate>
        <asp:PlaceHolder runat="server" ID="PlaceHolderFooter">
            FOOTER STUFF
        </asp:PlaceHolder>
    </FooterTemplate>
</asp:Repeater>

и затем в вашем коде позади

    protected void ShowHideHeaderFooter(object sender, RepeaterItemEventArgs e)
    {
        if(e.Item.ItemType == ListItemType.Header && theDataSource.Count == 0 && !ShowHeaderOnEmpty)
        {
            e.Item.FindControl("PlaceHolderHeader").Visible = false;
        }
        ...
    }
0 голосов
/ 17 сентября 2010

Я хотел бы создать пользовательский веб-элемент управления (.ascx), который содержит раздел заголовка, элемент управления [дочерний] повторитель и раздел нижнего колонтитула. Вы можете поместить всю свою логику в этот пользовательский элемент управления.

...