如何添加动态绑定用户控件

本文关键字:动态绑定 用户 控件 添加 何添加 | 更新日期: 2023-09-27 18:14:14

所以我有一个名为TagFilter的用户控件,它有2个中继器。控件将被添加到一个页面N次,每个repeater绑定到一个不同的数据表。

<%@ Control Language="C#" AutoEventWireup="true" CodeBehind="TagFilter.ascx.cs" Inherits="Hite.Web.Controls.TagFilter" %>
<div class="tagDiv">
<h3>
    <span style="">Results By :</span>
    <asp:Repeater ID="rptUsed" runat="server">
        <ItemTemplate>
            <span class="UsedTags">
                <asp:ImageButton ID="ImageButton1" runat="server" OnCommand="UsedPops_Remove" CommandArgument='<%# DataBinder.Eval(Container.DataItem, "tagid") %>'
                    ImageUrl="~/Images/errorIcon.png" />
                <a href="#">
                    <%# DataBinder.Eval(Container.DataItem, "tagname") %></a> </span>
        </ItemTemplate>
    </asp:Repeater>
</h3>
<asp:Repeater ID="rptUnused" runat="server">
    <ItemTemplate>
        <b style="padding-left: 5px; padding-right: 5px;">
            <asp:LinkButton ID="LinkButton1" runat="server" OnCommand="lbPop_Command" CommandArgument='<%# DataBinder.Eval(Container.DataItem, "tagid") %>'><%# DataBinder.Eval(Container.DataItem, "tagname") %>
            </asp:LinkButton></b>
    </ItemTemplate>
</asp:Repeater>
<br />
</div>
public partial class TagFilter : System.Web.UI.UserControl
{
    public DataTable UsedDT { get; set; }
    public DataTable UnusedDT { get; set; }
    public SearchParameters searchParams { get; set; }
    protected void Page_Load(object sender, EventArgs e)
    {
        rptUsed.DataSource = UsedDT;
        rptUsed.DataBind();
        rptUnused.DataSource = UnusedDT;
        rptUnused.DataBind();
    }

我循环使用一个有多个数据表的数据集,并尝试创建用户控件

            TagFilter tf = (TagFilter)Page.LoadControl("/Controls/TagFilter.ascx");
            tf.UnusedDT = ds.Tables[3];
            tf.UsedDT = ds.Tables[4];
            tagdiv.Controls.Add(tf);

当我在调试器中逐步执行代码时,数据表在分配给控件时具有行,但在page_Load上没有行。有人能帮我找出我的错误吗?这是一个页面生命周期问题吗?

如何添加动态绑定用户控件

你应该在usercontrol中创建一个方法。

public void BindData()
{
    rptUsed.DataSource = UsedDT;
    rptUsed.DataBind();
    rptUnused.DataSource = UnusedDT;
    rptUnused.DataBind();
}
然后调用
tf.BindData();