C# - 动态按钮的事件处理程序

时间:2012-08-22 08:29:33

标签: asp.net button event-handling webforms postback

我有一个使用设计模式创建的文本框和提交按钮。

按下提交按钮后,它将从文本框中检索用户输入,然后查询我的数据库。 然后,它将根据从我的数据库中检索到的信息显示动态按钮列表。

但是,单击时按钮的事件处理程序不会触发。我想我的问题是回发,但我无法在page_load等中创建这些按钮。因为我需要获取用户输入(在按下提交按钮时从文本框中),然后才能加载按钮。< / p>

我该如何解决这个问题?

谢谢。

修改(代码):

protected void subBtn_Click(object sender, EventArgs e)
{
       //database setup codes
        .......


       while (reader.Read())
       {
            Button detailsBtn = new Button();
            detailsBtn.Text = reader["fName"].ToString();
            //doesn't fire
            detailsBtn.Click += new EventHandler(detailsBtn_Click);
            memPanel.Controls.Add(detailsBtn);
       }
}

2 个答案:

答案 0 :(得分:3)

主要问题是如果这些控件不存在,Postback会在每次回发时重新生成动态控件。 有关快速演示,请参阅此代码

ASPX代码

<form id="form1" runat="server">
<asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" />
<asp:Panel ID="pnl" runat="server"></asp:Panel>
</form>

ASPX.CS代码

protected void Page_Load(object sender, EventArgs e)
        {
            if(IsPostBack)
            {
                generate();                
            }
        }
        public void generate()
        {
            if (!pnl.HasControls())
            {
                for (int i = 0; i < 4; i++)
                {
                    Button detailsBtn = new Button();
                    detailsBtn.Text = "fName" + i.ToString();
                    detailsBtn.ID = i.ToString();
                    detailsBtn.Click += new EventHandler(detailsBtn_Click);
                    pnl.Controls.Add(detailsBtn);
                }
            }
        }
        protected void Button1_Click(object sender, EventArgs e)
        {
            generate();
        }

        protected void detailsBtn_Click(object sender, EventArgs e)
        {
        }

答案 1 :(得分:0)

听起来像是您可以轻松地重构页面以使用简单的<asp:Repeater runat="server" ..></asp:Repeater>而不是动态地向Panel添加控件。

这是一个非常简单的完整样本:

<强> RepeaterTest.aspx

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="Server">
    <asp:TextBox ID="theTextBox" runat="server"></asp:TextBox>
    <asp:Button ID="theButton" runat="server" OnClick="theButton_Click" Text="Click me" />
    <asp:Repeater ID="test" runat="server">
        <ItemTemplate>
            <asp:Button ID="theRepeaterButton" runat="server" Text='<%# Eval("fName") %>' OnClick="theRepeaterButton_Click" />
        </ItemTemplate>
    </asp:Repeater>
</asp:Content>

<强> RepeaterTest.aspx.cs

public partial class RepeaterTest : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
    }
    protected void theButton_Click(object sender, EventArgs e)
    {
        string filter = theTextBox.Text;
        // below row simulates fetching data using the filter text in the text box
        var data = Enumerable.Range(0, 20).Select(i => new { fName = filter + " " + i });
        test.DataSource = data;
        test.DataBind();
    }
    protected void theRepeaterButton_Click(object sender, EventArgs e)
    {
        var button = (Button)sender;

        // do something here based on text/commandname/commandargument etc of the button

    }
}