在网格视图c#中添加行

本文关键字:添加行 视图 网格 | 更新日期: 2023-09-27 17:58:25

我是asp.net的新手。我想知道如何用程序在网格视图中添加一行。我能做到,但它只是显示了最新添加的内容。这是我的代码:

DataTable dt = new DataTable();
dt.Columns.Add("Question");
dt.Columns.Add("Answer");
DataRow dr = dt.NewRow();
dr["Question"] = txtQuestion.Text;
dr["Answer"] = txtAnswer.Text;
dt.Rows.Add(dr);
dt.AcceptChanges();
gvQnA.DataSource = dt;
gvQnA.DataBind();

在网格视图c#中添加行

这是因为您每次都要创建新表,并将其与网格绑定

执行以下代码可以解决您的问题。。。

在这里,我将获取现有的数据源,并通过再添加两行来再次绑定它。。。

DataTable dt = gridView.DataSource as DataTable;
if (dt != null)
{
  DataRow dr = dt.NewRow();
  dr["Question"] = txtQuestion.Text;
  dr["Answer"] = txtAnswer.Text;
  dt.Rows.Add(dr);
  dt.AcceptChanges();
  gvQnA.DataSource = dt;
  gvQnA.DataBind();
}

@Pranay是正确的。此外,您还可以通过使用DataTable作为属性来实现这一点。

  private DataTable Dt
    {
        set { ViewState.Add("Dt", value); }
        get { return (DataTable)ViewState["Dt"]; }
    }

DataRow dr = Dt.NewRow();
dr["Question"] = txtQuestion.Text;
dr["Answer"] = txtAnswer.Text;
Dt.Rows.Add(dr);
Dt.AcceptChanges();
gvQnA.DataSource = Dt;
gvQnA.DataBind();

您在代码中添加了一行,这就是它显示一行的原因。如果你添加了多行,它会显示正确的结果

DataTable dt = new DataTable();
dt.Columns.Add("Question");
dt.Columns.Add("Answer");
DataRow dr = dt.NewRow();
dr["Question"] = txtQuestion.Text;
dr["Answer"] = txtAnswer.Text;
dt.Rows.Add(dr);
**DataRow dr = dt.NewRow();
dr["Question"] = "2nd row";
dr["Answer"] = "2nd row";
dt.Rows.Add(dr);**
dt.AcceptChanges();
gvQnA.DataSource = dt;
gvQnA.DataBind();

可能是@Pranay也是正确的

嘿,看看这个。这可能有助于你

DataTable dataTable = new DataTable();
int columnsCount = // Set the number of the table's columns here.
for (int columnIndex = 0; columnIndex < columnsCount; columnIndex++)
{
    DataColumn dataColumn = new DataColumn();
    // Assign dataColumn properties' values here ..
    dataTable.Columns.Add(dataColumn);
}
int rowsCount = // Set the number of the table's rows here.
for (int columnIndex = 0; columnIndex < columnsCount; columnIndex++)
{
    DataRow dataRow = new DataRow();
    dataRow["ColumnName"] = // Set the value here ..
    dataTable.Rows.Add(dataRow);        
}