1

问题

PostBack我需要通过ASP 页面上的a 来维护动态创建的表的状态。

细节

当用户访问该页面时,会根据存储在数据库中的信息创建一个 CheckBoxes 表。基本上,这些复选框以网格形式排列,根据数据库中的信息选中/取消选中和启用/禁用。它们也是彩色编码的,但这并不重要。

网格的尺寸和复选框的状态在 处确定Page_Load。我有一个名为的类DisplayWell,它只是一个TableCell包含 CheckBox 的类。页面本身有一个空白Table,我循环并添加DisplayWells. 然后,用户可以对复选框的状态和少数几个 进行编辑TextFields,然后单击按钮进行保存。

我相信您知道,问题在于这些动态创建的对象在之后消失了Page_Load:服务器将它们交给客户端并且它们被销毁了。我需要能够保留表或对象数组的状态才能更新数据库。

到目前为止,我一直使用隐藏字段来存储我需要在回发中持久保存的信息,但仅限于一两个变量,这在这种情况下实际上是行不通的(通常我们谈论的是 96 个复选框,但它可以可以是任意数字)。我读过您可以将对象存储在会话变量中,但是对象的状态会在客户端进行更改吗?我也听说这是个坏主意。

编辑:测试后,更改未注册-我从会话变量中得到了相同的数组。

FWIW,这里是Page_Load

protected void Page_Load(object sender, EventArgs e)
{
    if (!Page.IsPostBack)
    {                
        if (Request.QueryString["Plate_INDEX"] != null &&
            Request.QueryString["Block_INDEX"] != null)
        {
            String sPIndex = Request.QueryString["Plate_INDEX"].ToString();
            String sBIndex = Request.QueryString["Block_INDEX"].ToString();
            if(-1 != Block_INDEX)
            {
                lblExpPlate.Text = "Edit a Solution";
                populateFields();
            }
            hfPlate_INDEX.Value = Plate_INDEX.ToString();
            hfBlock_INDEX.Value = Block_INDEX.ToString();                        
            createPlate();
            addToTable();                
        } // end queryString != null
    }
} // end Page_Load

private void createPlate()
{
    MTT_Plate_IO mpio = new MTT_Plate_IO();
    SqlDataReader plateReader = mpio.Get_Plate(Plate_INDEX);

    if (plateReader.Read())
    {
        r = (int)plateReader["Plate_Rows"];
        c = (int)plateReader["Plate_Columns"];
        hfPlate_INDEX.Value = plateReader["Plate_INDEX"].ToString();
        dwArr = new DisplayWell[r, c];
        for (int i = 0; i < r; i++)
        {
            for (int j = 0; j < c; j++)
            {
                dwArr[i, j] = new DisplayWell();
                dwArr[i, j].cb.Checked = false;
                dwArr[i, j].cb.Enabled = true;
            }
        } // end creation of plate                
    } // end plateReader
} //end createPlate();


private void addToTable()
{
    // create a header for the table
    TableRow header = new TableRow();
    TableHeaderCell blankCell = new TableHeaderCell();
    header.Cells.Add(blankCell); //blank cell to align with data

    // add numbers to top of plate
    for (int i = 1; i <= c; i++)
    {
        TableHeaderCell thc = new TableHeaderCell();
        thc.Text = i.ToString();
        header.Cells.Add(thc);
    }
    tblPlate.Rows.Add(header);

    //create the plate
    for (int i = 0; i < r; i++)
    {
        TableRow tr = new TableRow();
        TableCell rowHeader = new TableCell();
        rowHeader.CssClass = "style5";
        //add a letter to the beginning of the row
        String rowHeaderText = ((char)(i + 65)).ToString();
        rowHeader.Text = rowHeaderText;
        tr.Cells.Add(rowHeader);
        for (int j = 0; j < c; j++)
        {
            tr.Cells.Add(dwArr[i, j].tc);
        }

        tblPlate.Rows.Add(tr);
    }
}    
4

1 回答 1

0

感谢Andrew-Barber的建议,我希望他能出现并回答这个问题(你仍然可以!),我想出了解决方案:

在方法中创建对象OnInit并删除if(!Page.IsPostBack)块,而不是为页面的每个实例实例化对象。这发生在页面生命周期的早期,并将对象持久保存在服务器端的内存中,允许注册客户端所做的更改。

于 2012-08-16T14:00:46.083 回答