簡體   English   中英

如何向Gridview添加新行?

[英]How to add a new Row to the Gridview?

我有一個帶有3個TemplateFields的Gridview:1個帶有DropDownList,另外2個帶有Texboxes。

我設法在GridView中獲得第一個空行。 現在,我需要在DropDownList的SelectedIndexChanged事件上添加另一行。

我該如何實現?

謝謝

Default.aspx

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:ScriptManager runat="server">
        </asp:ScriptManager>
        <asp:UpdatePanel runat="server">
            <ContentTemplate>
                <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" 
                    Width="317px">
                    <Columns>
                        <asp:TemplateField HeaderText="Text 1">
                            <ItemTemplate>
                                <asp:TextBox runat="server" Visible='<%# Eval("isLast") %>' ID="Text1"></asp:TextBox>
                                <asp:Label runat="server" Visible='<%# !(bool)Eval("isLast") %>' Text='<%# Eval("text1") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField HeaderText="Text 2">
                            <ItemTemplate>
                                <asp:TextBox runat="server" Visible='<%# Eval("isLast") %>' ID="Text2"></asp:TextBox>
                                <asp:Label runat="server" Visible='<%# !(bool)Eval("isLast") %>' Text='<%# Eval("text2") %>'></asp:Label>
                            </ItemTemplate>
                        </asp:TemplateField>
                        <asp:TemplateField>
                            <ItemTemplate>
                                <asp:DropDownList ID='DropDownList' Visible='<%# Eval("isLast") %>' runat="server" 
                                    onselectedindexchanged="DropDownList_SelectedIndexChanged" AutoPostBack="true">
                                    <asp:ListItem Text="Option 1" Value="1" />
                                    <asp:ListItem Text="Option 2" Value="2" />
                                    <asp:ListItem Text="Option 3" Value="3" />
                                </asp:DropDownList>
                            </ItemTemplate>
                        </asp:TemplateField>
                    </Columns>
                </asp:GridView>
            </ContentTemplate>
        </asp:UpdatePanel>
    </div>
    </form>
</body>
</html>

Default.aspx.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Data;

public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            DataTable dt = new DataTable("table1");
            dt.Columns.Add("ID", Type.GetType("System.Int32"));
            dt.Columns.Add("text1");
            dt.Columns.Add("text2");
            dt.Columns.Add("isLast", Type.GetType("System.Boolean"));
            for (int i = 0; i < 3; i++)
            {
                dt.Rows.Add(new object[] { 
                    i, 
                    i < 2 ? "text 1 row " + i : string.Empty, 
                    i < 2 ? "text 2 row " + i : string.Empty, 
                    i == 2 });
            }
            GridView1.DataSource = dt;
            GridView1.DataBind();
            Session["dataTable"] = dt; // change to sql data source
        }
    }
    protected void DropDownList_SelectedIndexChanged(object sender, EventArgs e)
    {
        DropDownList ddl = (DropDownList)sender;
        DataTable dt = (DataTable)Session["dataTable"];
        var maxId = dt.AsEnumerable().Max(row => Convert.ToInt32(row["ID"]));
        var dataRow = dt.AsEnumerable().Where(row => (int)row["ID"] == maxId)
                        .Select(row => row)
                        .FirstOrDefault();
        dataRow["text1"] = ((TextBox)GridView1.Rows[GridView1.Rows.Count - 1].FindControl("Text1")).Text;
        dataRow["text2"] = ((TextBox)GridView1.Rows[GridView1.Rows.Count - 1].FindControl("Text2")).Text;
        dataRow["isLast"] = false;
        dt.Rows.Add(new object[] { maxId + 1, string.Empty, string.Empty, true });
        GridView1.DataSource = dt;
        GridView1.DataBind();
        Session["dataTable"] = dt;
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM