0

コードビハインドで構築しています。テーブルはデータベース レコード (行ごとに 1 つのレコード) のリストであり、行ごとに削除ボタンを追加する必要があります。そのためには、もちろん、そのための一意の ID を持つボタンを作成する必要があります。そのために、私は次のことを思いつきました...うまくいきません。これを機能させるためのヒントはありますか?

Button deleteButton = new Button();
deleteButton.ID = "deleteStudentWithID" + singleStudent.ID.ToString();
deleteButton.Text = "X";

string row = "<tr>";
row += "<td class=\"style5\">"+deleteButton.ClientID +"</td>";
row += "</tr>";
4

3 に答える 3

5

問題はClientID、コントロールの1つだけをhtmlに追加し、コントロールをページ自体に追加しないことです。

Controls.Add(new LiteralControl("<table>"));

foreach(var singleStudent in students)
{
    Controls.Add(new LiteralControl("<tr>"));

    //Code to add other columns

    Button deleteButton = new Button();
    deleteButton.ID = "deleteStudentWithID" + singleStudent.ID.ToString();
    deleteButton.Text = "X";

    Controls.Add(new LiteralControl("<td class=\"style5\">"));
    Controls.Add(deleteButton);
    Controls.Add(new LiteralControl("</td></tr>");
}

Controls.Add(new LiteralControl("</table>"));
于 2012-05-01T12:55:53.083 に答える
3

コード ビハインドでテーブル全体のマークアップを作成する代わりに、ASP.NET で使用できるコントロールを使用します。

たとえば、これを .aspx に配置します。

<table>
    <asp:Repeater runat="server" ID="MyRepeater1">
        <ItemTemplate>
            <tr>
                <td><%# Eval("StudentName")%></td>
                <td>... other student object bindings ...</td>
                <td>
                    <asp:Button runat="server" ID="MyDeleteButton"
                            CommandArgument='<%# Eval("ID")%>'
                            CommandName="Delete"
                            OnCommand="MyDeleteButton_Command"
                            Text="X" />
                </td>
            </tr>
        </ItemTemplate>
    </asp:Repeater>
</table>

これをコード ビハインドに含めます。

protected void Page_Load(object sender, EventArgs e)
{
    MyRepeater1.DataSource = new MyStudent[]
        {
            new MyStudent()
                {
                    ID = 1,
                    StudentName = "Student 1"
                },
            new MyStudent()
                {
                    ID = 2,
                    StudentName = "Student 2"
                }
        };
    MyRepeater1.DataBind();
}

protected void MyDeleteButton_Command(object sender, CommandEventArgs e)
{
    switch (e.CommandName)
    {
        case "Delete":
            // stuff for deleting by e.CommandArgument
            break;
    }
}
于 2012-05-01T13:52:41.870 に答える
1

私が考えることができるあなたの問題に対する最善の解決策は

Button deleteButton = new Button();
deleteButton.ID = "deleteStudentWithID" + singleStudent.ID.ToString();
deleteButton.Text = "X";

StringBuilder sb = new StringBuilder();
StringWriter writer = new StringWriter(sb);
HtmlTextWriter htmlWriter = new HtmlTextWriter(writer);
deletedButton.RenderControl(htmlWriter);

string row = "<tr>";
row += "<td class=\"style5\">"+sb.toString(); +"</td>";
row += "</tr>";

このようにして、任意のコントロールの HTML を取得できます。:) コード ビハインドから HTML を動的に構築する場合は、文字列ではなく StringBuilder を使用しないようにしてください。文字列は不変であり、パフォーマンスが低下します。

于 2012-05-01T13:10:08.880 に答える