コード ビハインドで完全に動的に作成されたページがあります (うれしいです)。
このページのボタンを押すと、さらに要素がページに追加されます。これは問題ありませんが、更新されたページは次のポストバックまで表示されません。リダイレクトを行いますが、既存のコントロールに入力されたデータの状態を維持したいと考えています。
そのため、サーバー コード ビハインド コードから強制的にポストバックする必要があります。これにはいくつかのjsコードを挿入する必要があると思いますが、それ以上はまったく喜びがありませんでした.
わかりやすくするための例を次に示します。
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default2.aspx.cs" Inherits="Default2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
</head>
<body>
<form id="form1" runat="server">
<div>
<asp:Button ID="Button1" runat="server" Text="Button" onclick="Button1_Click" />
<asp:PlaceHolder ID="PlaceHolder1" runat="server"></asp:PlaceHolder>
</div>
</form>
</body>
</html>
とてもシンプルなページです。
コードビハインドもシンプルです:
using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
public partial class Default2 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
Session["data"] = 1;
}
PopulatePage();
}
private void PopulatePage()
{
int data = (int)Session["data"];
for (int n = 0; n < data; ++n)
{
TextBox tb = new TextBox();
tb.ID = n.ToString();
PlaceHolder1.Controls.Add(tb);
Literal lit = new Literal();
lit.Text = "<br/>";
PlaceHolder1.Controls.Add(lit);
}
}
protected void Button1_Click(object sender, EventArgs e)
{
int data = (int)Session["data"];
Session["data"] = ++data;
}
}
ボタンをクリックすると、さらにコントロールが追加されます。これは、私が問題を抱えているページよりもはるかに単純ですが、私が抱えている問題を示しています。