DataTable中的列消失

时间:2015-06-04 17:17:48

标签: c# asp.net datatable

我有一个DataTable,它在页面加载时生成了列。因为我不希望每次发生回发时都重新创建这个表,所以我在no-postback if语句中使用它。即:

DataTable purchase_display_data = new DataTable();

protected void Page_Load(object sender, EventArgs e)
{
    if(!IsPostBack)
    {
        DataColumn rownumber = new DataColumn();
        rownumber.DataType = System.Type.GetType("System.Int16");
        rownumber.AutoIncrement = true;
        rownumber.AutoIncrementSeed = 1;
        rownumber.AutoIncrementStep = 1;

        purchase_display_data.Columns.Add(rownumber);
        purchase_display_data.Columns.Add("Item");
        purchase_display_data.Columns.Add("Charge");
    }
}

稍后,我按下按钮后尝试添加数据。用:

protected void buttonOK_Click(object sender, EventArgs e)
{
    DataRow newline = purchase_display_data.NewRow();
    newline[1] = "1";
    newline[2] = "2";
    purchase_display_data.Rows.Add(newline);
}

按下所述按钮后,我返回一个错误,指出该列未找到。在调试中,我注意到我的DataTable没有列,尽管在页面加载时成功创建了它们(每次调试和其他测试)。这些专栏似乎已经消失了。有人可以告诉我为什么会这样,当然还有如何修复它。

1 个答案:

答案 0 :(得分:4)

您在回发时丢失了数据。这是正常的。您必须使用一些状态管理机制,如ViewStateSession来提及一些。

您可以使用ViewState

尝试此操作
private DataTable purchase_display_data
{
    get
    {
        if (ViewState["purchase_display_data"] == null)
            ViewState["purchase_display_data"] = new DataTable();
        return (DataTable)ViewState["purchase_display_data"];
    }
    set { ViewState["purchase_display_data"] = value; }
}