1

ユーザーがボタンを複数回クリックした場合、テキストを複数回表示したい。たとえば、ボタンを 4 回クリックした場合、4 つのテキストが表示されるようにします。ただし、複数回表示されないという問題が進行中です。

ユーザーがボタンを 3 回押すと、次のように表示されることを期待していました。

Hello world
Hello world
Hello world

しかし、それは私にこれを示しました:

Hello world

この問題で私を助けることができる人はいますか....

ソースコードは次のとおりです。

Webform1.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx.cs"  Inherits="addlabels.WebForm1" %>

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:Panel ID="Panel1" runat="server"></asp:Panel>
        <asp:Button ID="add" runat="server" Text="Add more" OnClick="add_click"/>

    </div>
    </form>
</body>
</html>

WebForm1.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

using System.Diagnostics;
using System.Text;

namespace addlabels
{
    public partial class WebForm1 : System.Web.UI.Page
    {

        int pressNumberOfTimes;

        protected void Page_Load(object sender, EventArgs e)
        {

        }


        protected void add_click(object sender, EventArgs e)
        {
            // Add the panel
            pressNumberOfTimes++;

            Label lbl_homeCarouselAdd = new Label();

            // Set the label's Text and ID properties.
            lbl_homeCarouselAdd.ID = "lbl_homeCarouselAdd" + pressNumberOfTimes;

            StringBuilder strDiv = new StringBuilder();
            strDiv.Append(string.Format(@"<p class='style'>Hello world</p>"));

            lbl_homeCarouselAdd.Text = strDiv.ToString();


            Panel1.Controls.Add(lbl_homeCarouselAdd);
        }
    }
}
4

2 に答える 2

2

解決策 1: 新しいラベルを古いラベルに置き換えているだけで、既存のラベルに追加していないため、ボタンを複数回クリックしても複数のラベルが表示されません。

これを置き換えます:

lbl_homeCarouselAdd.Text = strDiv.ToString();

次の場合:

lbl_homeCarouselAdd.Text += strDiv.ToString();

解決策 2:

毎回ラベルを作成する必要はないので、ラベル宣言を関数の外に移動します。

解決策 3:

動的に作成されたすべてのコントロールが削除されるたびにページをサーバーにポストバックすると (ここでは、ラベルが削除されます)。したがって、次の使用のために保持するために、ラベル データを何らかの変数に保持する必要があります。ここでは、古いラベル データを保存するために StringBuilder を使用しました。より良いアプローチについては、動的に作成されたコントロールがデータを失うリンクを参照してください。

変更されたコードは次のようになります。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

using System.Diagnostics;
using System.Text;

namespace addlabels
{
    public partial class WebForm1 : System.Web.UI.Page
    {

        int pressNumberOfTimes;
        Label lbl_homeCarouselAdd = new Label();
        static StringBuilder strDiv = new StringBuilder();
        protected void Page_Load(object sender, EventArgs e)
        {

        }


        protected void add_click(object sender, EventArgs e)
        {
            // Add the panel
            pressNumberOfTimes++;



            // Set the label's Text and ID properties.
            lbl_homeCarouselAdd.ID = "lbl_homeCarouselAdd" + pressNumberOfTimes;


            strDiv.Append(string.Format(@"<p class='style'>Hello world</p>"));

            lbl_homeCarouselAdd.Text += strDiv.ToString();


            Panel1.Controls.Add(lbl_homeCarouselAdd);
        }
    }
}
于 2013-11-10T08:45:43.577 に答える
1

ボタンをクリックするポストバックごとに、フィールドの値.Textが消去されます。値を静的文字列変数に保持してみてください。その他の解決策と詳細については、以下のリンクを参照してください。

ここここを参照してください。

于 2013-11-10T08:42:21.960 に答える