1

Viewstate Concept を使用してグリッドに新しい行を追加しています。しかし、最後の行を削除できません。デフォルトでは、空の行をグリッドにバインドしています。

// 新しい行を追加

if (ViewState["CurrentTable"] != null)
        {
            DataTable dtCurrentTable = (DataTable)ViewState["CurrentTable"];
            DataRow drCurrentRow = null;
            int i;

            if (dtCurrentTable.Rows.Count > 0)
            {
                for (i = 1; i <= dtCurrentTable.Rows.Count; i++)
                {
                    TextBox txtguide = (TextBox)grdreports.Rows[rowIndex].FindControl("txtAccNo");
 dtCurrentTable.Rows[i - 1]["txtAccNo"] = txtguide.Text;
  }
                drCurrentRow = dtCurrentTable.NewRow();
                dtCurrentTable.Rows.Add(drCurrentRow);
                ViewState["CurrentTable"] = dtCurrentTable;
                ViewState["rowcount"] = dtCurrentTable.Rows.Count;
                grdreports.DataSource = dtCurrentTable;
                grdreports.DataBind();

            }

// 最後の行を削除

if (Grid.Rows.Count > 1)
    {
        if (ViewState["CurrentTable"] != null)
        {
            DataTable dtCurrentTable = (DataTable)ViewState["CurrentTable"];
            dtCurrentTable.Rows.RemoveAt(dtCurrentTable.Rows.Count);
            ViewState["CurrentTable"] = dtCurrentTable;
            Grid.DataSource = dtCurrentTable;
            Grid.DataBind();

        }
        else
        {
            Response.Write("ViewState is null");
        }
    }

どこが間違っていますか?

4

2 に答える 2

0

削除中にカウントを取り、そこから 1 を引きます。それはうまくいきます。

if (Grid.Rows.Count > 1)
        {
            if (ViewState["CurrentTable"] != null)
            {
                DataTable dtCurrentTable = (DataTable)ViewState["CurrentTable"];
                dtCurrentTable.Rows.RemoveAt(dtCurrentTable.Rows.Count -1);
                ViewState["CurrentTable"] = dtCurrentTable;
                Grid.DataSource = dtCurrentTable;
                Grid.DataBind();

            }
            else
            {
                Response.Write("ViewState is null");
            }
        }
于 2012-11-30T06:16:57.577 に答える
0

DataTable.Rows は 0 ベースのインデックスです。その最後の行を削除したい場合は、count - 1 を使用する必要があります

dtCurrentTable.Rows.RemoveAt(dtCurrentTable.Rows.Count - 1);
于 2012-11-30T06:17:40.903 に答える