无法在 asp.net 中动态添加多个服务器控件

本文关键字:添加 服务器控件 动态 asp net | 更新日期: 2023-09-27 18:36:52

嗨,自从几天以来,我真的被困在我的一项开发任务中,我无法确切地找出发生了什么。请帮忙。

我正在尝试将行动态添加到网页,如下所示。我想使用服务器控件。但是我无法添加多行。

即使我使用了会话变量,也没有运气。请帮忙:)

-----------------aspx 文件---------------

<div>
    <asp:Table ID="tbl" runat="server">
        <asp:TableRow ID="rw0">
            <asp:TableCell ID="c01" Width="100px">
                <asp:CheckBox runat="server" ID="chk0" />
            </asp:TableCell>
            <asp:TableCell ID="c02" Width="100px">
                <asp:TextBox runat="server" ID="txt0" />
            </asp:TableCell></asp:TableRow>
        <asp:TableRow ID="rw1">
            <asp:TableCell ID="c11" Width="100px">
                <asp:CheckBox ID="chk1" runat="server" />
            </asp:TableCell><asp:TableCell ID="c12" Width="100px">
                <asp:TextBox runat="server" ID="txt1" />
            </asp:TableCell></asp:TableRow>
    </asp:Table>
    <asp:Button ID="btn1" runat="server" Text="Add Row" OnClick="addRow" />
</div>

---------------------C# 代码隐藏------------------------------

protected void addRow(object sender, EventArgs e)
    {
        int num_row = new int(); //checkpoint
        num_row = (tbl.Rows).Count;
        if (Session["tables"] != null)
        {
            tbl =  (Table)Session["tables"];
        }

        TableRow row = new TableRow();
        TableCell cell1 = new TableCell();
        TableCell cell2 = new TableCell();
        TextBox tb = new TextBox();
        CheckBox cb = new CheckBox();
        row.ID = "rw" + num_row;
        cell1.ID = "c" + num_row + "1";
        cell2.ID = "c" + num_row + "2";
        tb.ID = "txt" + num_row;
        tb.EnableViewState = true;
        cb.ID = "chk" + num_row;
        cell1.Controls.Add(tb);
        cell2.Controls.Add(cb);
        row.Cells.Add(cell1);
        row.Cells.Add(cell2);
        tbl.Rows.Add(row);
        Session["tables"] = tbl;

    }

无法在 asp.net 中动态添加多个服务器控件

您每次只能看到添加一行,因为动态创建的控件在回发中不可用。

当您第一次单击添加行时,会发生回发,并添加第三行。 当您第二次单击添加行时,已添加的行将不可用,并且会再次添加新行。最后,您每次只能看到一行。

底线是您必须在 page_load 事件中每次回发时重新创建动态添加的控件,原因是动态添加的服务器 sontrols 不会在回发中持续存在

请参阅为什么动态创建的用户控件在控件未执行完全回发时消失?

若要维护动态添加的控件的视图状态,必须为控件生成 ID。在回发期间重新创建控件时,请使用相同的 ID 重新创建它们,以便维护视图状态。

使用一些标准逻辑为控件生成 ID。 希望这有帮助。

更新:

protected void Page_Load(object sender, EventArgs e)
        {
            if (IsPostBack)
            {
                int num_row = (int)Session["No_of_Rows"];
                for (int i = 2; i < num_row; i++)
                {
                    TableRow row = new TableRow();
                    TableCell cell1 = new TableCell();
                    TableCell cell2 = new TableCell();
                    TextBox tb = new TextBox();
                    CheckBox cb = new CheckBox();
                    row.ID = "rw" + i;
                    cell1.ID = "c" + i + "1";
                    cell2.ID = "c" + i + "2";
                    tb.ID = "txt" + i;
                    tb.EnableViewState = true;
                    cb.ID = "chk" + i;
                    cell1.Controls.Add(cb);
                    cell2.Controls.Add(tb);
                    row.Cells.Add(cell1);
                    row.Cells.Add(cell2);
                    tbl.Rows.Add(row);
                }
            }
            else
            {
                Session["No_of_Rows"] = 2;
            }
        }
        protected void addRow(object sender, EventArgs e)
        {
            int num_row = (int)Session["No_of_Rows"]+1;
            TableRow row = new TableRow();
            TableCell cell1 = new TableCell();
            TableCell cell2 = new TableCell();
            TextBox tb = new TextBox();
            CheckBox cb = new CheckBox();
            row.ID = "rw" + num_row;
            cell1.ID = "c" + num_row + "1";
            cell2.ID = "c" + num_row + "2";
            tb.ID = "txt" + num_row;
            tb.EnableViewState = true;
            cb.ID = "chk" + num_row;
            cell1.Controls.Add(cb);
            cell2.Controls.Add(tb);
            row.Cells.Add(cell1);
            row.Cells.Add(cell2);
            tbl.Rows.Add(row);
            Session["No_of_Rows"] = tbl.Rows.Count;
        }

在故事列中输入值后,如何将所有值保存在数据库表中?