C# Gridview是否总是在单击按钮时添加新行?

C# Gridview是否总是在单击按钮时添加新行?,c#,asp.net,linq,ado.net,updatepanel,C#,Asp.net,Linq,Ado.net,Updatepanel,我正在编写在gridview中单击按钮时创建新行的代码。行数由textbox中的值创建。例如:当我在文本框中输入值2时,当然会添加两行,但当我再次单击按钮时,第三行仍然会添加。请在这里检查我的代码: ASPX <asp:TextBox ID="txtVisitor" runat="server"></asp:TextBox> <asp:UpdatePanel ID="UpdatePanel1" runat="server"> <ContentTe

我正在编写在gridview中单击按钮时创建新行的代码。行数由textbox中的值创建。例如:当我在文本框中输入值2时,当然会添加两行,但当我再次单击按钮时,第三行仍然会添加。请在这里检查我的代码:

ASPX

<asp:TextBox ID="txtVisitor" runat="server"></asp:TextBox>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <ContentTemplate>
        <asp:GridView ID="Gridview1" runat="server" ShowFooter="true" AutoGenerateColumns="false">
            <Columns>
                <asp:BoundField DataField="RowNumber" HeaderText="Row Number" />
                <asp:TemplateField HeaderText="Header 1">
                    <ItemTemplate>
                        <asp:TextBox ID="txtDate" runat="server"></asp:TextBox>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="Header 2">
                    <ItemTemplate>
                        <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="Header 3">
                    <ItemTemplate>
                        <asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
                    </ItemTemplate>
                    <FooterStyle HorizontalAlign="Right" />
                    <FooterTemplate>
                        <asp:Button ID="ButtonAdd" runat="server" Text="Add New Row" OnClick="ButtonAdd_Click" />
                    </FooterTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
    </ContentTemplate>
</asp:UpdatePanel>

暗藏

protected void ButtonAdd_Click(object sender, EventArgs e)
{
    int visitors = Convert.ToInt32(txtVisitor.Text);
    AddNewRowToGrid(visitors);
}

private void SetInitialRow()
{
    DataTable dt = new DataTable();
    DataRow dr = null;
    dt.Columns.Add(new DataColumn("RowNumber", typeof(string)));
    dt.Columns.Add(new DataColumn("Column1", typeof(string)));
    dt.Columns.Add(new DataColumn("Column2", typeof(string)));
    dt.Columns.Add(new DataColumn("Column3", typeof(string)));
    dr = dt.NewRow();
    dr["RowNumber"] = 1;
    dr["Column1"] = string.Empty;
    dr["Column2"] = string.Empty;
    dr["Column3"] = string.Empty;
    dt.Rows.Add(dr);
    //dr = dt.NewRow();

    //Store the DataTable in ViewState
    ViewState["CurrentTable"] = dt;

    Gridview1.DataSource = dt;
    Gridview1.DataBind();
}

private void AddNewRowToGrid(int visitors)
{
    if (ViewState["CurrentTable"] != null)
    {
        DataTable dtCurrentTable = (DataTable)ViewState["CurrentTable"];
        DataRow drCurrentRow;
        if (dtCurrentTable.Rows.Count > 0)
        {
            int rowindex = 0;

            for (int i = 1; i < visitors; i++)
            {
                //extract the TextBox values
                TextBox box1 = (TextBox)Gridview1.Rows[rowindex].Cells[1].FindControl("txtDate");
                TextBox box2 = (TextBox)Gridview1.Rows[rowindex].Cells[2].FindControl("TextBox2");
                TextBox box3 = (TextBox)Gridview1.Rows[rowindex].Cells[3].FindControl("TextBox3");

                drCurrentRow = dtCurrentTable.NewRow();
                drCurrentRow["RowNumber"] = i + 1;
                drCurrentRow["Column1"] = box1.Text;
                drCurrentRow["Column2"] = box2.Text;
                drCurrentRow["Column3"] = box3.Text;
                dtCurrentTable.Rows.Add(drCurrentRow);
                drCurrentRow = null;
                rowindex++;
            }
            //add new row to DataTable

            //Store the current data to ViewState
            ViewState["CurrentTable"] = dtCurrentTable;

            //Rebind the Grid with the current data
            Gridview1.DataSource = dtCurrentTable;
            Gridview1.DataBind();
        }
    }
    else
    {
        Response.Write("ViewState is null");
    }
}

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {
        SetInitialRow();
    }
}
protectedvoid按钮添加并单击(对象发送者,事件参数e)
{
int visors=Convert.ToInt32(txtVisitor.Text);
AddNewRowToGrid(访客);
}
私有void SetInitialRow()
{
DataTable dt=新的DataTable();
数据行dr=null;
添加(新的数据列(“行数”,typeof(字符串));
Add(新的数据列(“Column1”,typeof(string));
Add(新的数据列(“Column2”,typeof(string));
Add(新的数据列(“Column3”,typeof(string));
dr=dt.NewRow();
dr[“行数”]=1;
dr[“Column1”]=string.Empty;
dr[“Column2”]=string.Empty;
dr[“Column3”]=string.Empty;
dt.Rows.Add(dr);
//dr=dt.NewRow();
//将数据表存储在ViewState中
视图状态[“当前表”]=dt;
Gridview1.DataSource=dt;
Gridview1.DataBind();
}
私有void AddNewRowToGrid(int访问者)
{
如果(ViewState[“CurrentTable”]!=null)
{
DataTable dtCurrentTable=(DataTable)视图状态[“CurrentTable”];
数据行drCurrentRow;
如果(dtCurrentTable.Rows.Count>0)
{
int rowindex=0;
对于(int i=1;i
您的代码有一个问题:

//extract the TextBox values
TextBox box1 = (TextBox)Gridview1.Rows[rowindex].Cells[1].FindControl("txtDate");
TextBox box2 = (TextBox)Gridview1.Rows[rowindex].Cells[2].FindControl("TextBox2");
TextBox box3 = (TextBox)Gridview1.Rows[rowindex].Cells[3].FindControl("TextBox3");
for (int i = dtCurrentTable.Rows.Count; i < visitors; i++)
            {
                //extract the TextBox values
                TextBox box1 = (TextBox)Gridview1.Rows[rowindex].Cells[1].FindControl("txtDate");
                TextBox box2 = (TextBox)Gridview1.Rows[rowindex].Cells[2].FindControl("TextBox2");
                TextBox box3 = (TextBox)Gridview1.Rows[rowindex].Cells[3].FindControl("TextBox3");

                drCurrentRow = dtCurrentTable.NewRow();
                drCurrentRow["RowNumber"] = i + 1;
                drCurrentRow["Column1"] = box1.Text;
                drCurrentRow["Column2"] = box2.Text;
                drCurrentRow["Column3"] = box3.Text;
                dtCurrentTable.Rows.Add(drCurrentRow);
                drCurrentRow = null;
                rowindex++;
            }
这种逻辑是有缺陷的,甚至没有必要,因为当您绑定网格时,它将遍历您作为
数据源提供的集合,并使用您在标记中定义的
模板字段来创建每一行

在绑定到数据源之前,这些行实际上不会添加到GridView中,在您的示例中是一个
DataTable
,如下所示:

Gridview1.DataSource = dt;
Gridview1.DataBind();
步骤1是从
AddNewRowToGrid
方法中删除
FindControl

我甚至不确定您试图在代码中实现什么。

您的代码有一个问题:

//extract the TextBox values
TextBox box1 = (TextBox)Gridview1.Rows[rowindex].Cells[1].FindControl("txtDate");
TextBox box2 = (TextBox)Gridview1.Rows[rowindex].Cells[2].FindControl("TextBox2");
TextBox box3 = (TextBox)Gridview1.Rows[rowindex].Cells[3].FindControl("TextBox3");
for (int i = dtCurrentTable.Rows.Count; i < visitors; i++)
            {
                //extract the TextBox values
                TextBox box1 = (TextBox)Gridview1.Rows[rowindex].Cells[1].FindControl("txtDate");
                TextBox box2 = (TextBox)Gridview1.Rows[rowindex].Cells[2].FindControl("TextBox2");
                TextBox box3 = (TextBox)Gridview1.Rows[rowindex].Cells[3].FindControl("TextBox3");

                drCurrentRow = dtCurrentTable.NewRow();
                drCurrentRow["RowNumber"] = i + 1;
                drCurrentRow["Column1"] = box1.Text;
                drCurrentRow["Column2"] = box2.Text;
                drCurrentRow["Column3"] = box3.Text;
                dtCurrentTable.Rows.Add(drCurrentRow);
                drCurrentRow = null;
                rowindex++;
            }
for(int i=dtCurrentTable.Rows.Count;i
你把i设为1 替换为gridview的行数
从它开始

好的,你能解释一下文本框的意义吗?我正在运行您的代码,如果我输入了除2以外的任何内容,那么它不会添加任何行。这是因为您正试图通过GridView的rows集合查找textbox控件,并且由于网格中只有一行可以开始,如果您键入的值大于2,则在第一次循环迭代后,它会爆炸。@Karl我的代码中有什么错误。希望你能帮我当我找到控制时我会出错。我认为FindControl很好好,好的,让我们在一分钟内回到
FindControl
,但是访问者文本框是怎么处理的,为什么它控制循环发生的次数?这段代码很好,但现在我想通过在文本框中指定值来添加新行。@user2494232-祝你好运,我不知道你到底想干什么。说代码运行良好,然后请某人帮助您修复,这是非常矛盾的。尝试解释应该发生什么和实际发生什么,因为我无法理解您使用此UI和逻辑的意图。@user2494232-只是想让您知道,您的
for(int I=1;I
循环的编写方式,哟