Skip to main content

Add Dynamic Row In Grid

--------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------
<div>
        <br />
        No. of&nbsp; Person :
        <asp:DropDownList ID="ddl" runat="server" AutoPostBack="True"
            onselectedindexchanged="ddl_SelectedIndexChanged">
        <asp:ListItem Text="1" />
        <asp:ListItem Text="2" />
        <asp:ListItem Text="3" />
        <asp:ListItem Text="4" />
        </asp:DropDownList>
        <asp:GridView ID="Gridview1" runat="server" ShowFooter="True"
            AutoGenerateColumns="False" BackColor="White" BorderColor="#999999"
            BorderStyle="None" BorderWidth="1px" CellPadding="3" GridLines="Vertical">
            <FooterStyle BackColor="#CCCCCC" ForeColor="Black" />
            <RowStyle BackColor="#EEEEEE" ForeColor="Black" />
            <Columns>
                <asp:BoundField DataField="RowNumber" HeaderText="S. No." />
                <asp:TemplateField HeaderText="Header 1">
                    <ItemTemplate>
                        <asp:TextBox ID="TextBox1" 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>
            <PagerStyle BackColor="#999999" ForeColor="Black" HorizontalAlign="Center" />
            <SelectedRowStyle BackColor="#008A8C" Font-Bold="True" ForeColor="White" />
            <HeaderStyle BackColor="#000084" Font-Bold="True" ForeColor="White" />
            <AlternatingRowStyle BackColor="#DCDCDC" />
        </asp:GridView>
    </div>
--------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------

protected void ddl_SelectedIndexChanged(object sender, EventArgs e)
    {
        //AddNewRowToGrid();


        #region Create Columns
        dt_tempReservation = new DataTable();
        dt_tempReservation.Columns.Add(new DataColumn("RowNumber", typeof(string)));
        dt_tempReservation.Columns.Add(new DataColumn("Column1", typeof(string)));
        dt_tempReservation.Columns.Add(new DataColumn("Column2", typeof(string)));
        dt_tempReservation.Columns.Add(new DataColumn("Column3", typeof(string)));
        #endregion

        #region Data Save in dt_tempReservation (Datatable)
        DataRow drCurrentRow;
        for (int i = 0; i < Gridview1.Rows.Count; i++)
        {
            TextBox box1 = (TextBox)Gridview1.Rows[i].Cells[1].FindControl("TextBox1");
            TextBox box2 = (TextBox)Gridview1.Rows[i].Cells[2].FindControl("TextBox2");
            TextBox box3 = (TextBox)Gridview1.Rows[i].Cells[3].FindControl("TextBox3");

            drCurrentRow = dt_tempReservation.NewRow();
            drCurrentRow["RowNumber"] = i + 1;

            drCurrentRow["Column1"] = box1.Text;
            drCurrentRow["Column2"] = box2.Text;
            drCurrentRow["Column3"] = box3.Text;

            dt_tempReservation.Rows.Add(drCurrentRow);
        }
        #endregion

        int NoofRows = Convert.ToInt32(ddl.SelectedItem.Text);

        #region Required Rows Created
        DataTable dt = new DataTable();
        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)));
        for (int i = 0; i < NoofRows; i++)
        {
            DataRow dr = null;

            dr = dt.NewRow();

            dr["RowNumber"] = i + 1;
            dr["Column1"] = string.Empty;
            dr["Column2"] = string.Empty;
            dr["Column3"] = string.Empty;
            dt.Rows.Add(dr);
        }
        #endregion

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

        for (int i = 0; i < dt.Rows.Count; i++)
        {
            try
            {
                TextBox box1 = (TextBox)Gridview1.Rows[i].Cells[1].FindControl("TextBox1");
                TextBox box2 = (TextBox)Gridview1.Rows[i].Cells[2].FindControl("TextBox2");
                TextBox box3 = (TextBox)Gridview1.Rows[i].Cells[3].FindControl("TextBox3");

                box1.Text = dt_tempReservation.Rows[i]["Column1"].ToString();
                box2.Text = dt_tempReservation.Rows[i]["Column2"].ToString();
                box3.Text = dt_tempReservation.Rows[i]["Column3"].ToString();
            }
            catch (Exception ex) { }
        }
        //Gridview1.DataSource = dt_tempReservation;
        //Gridview1.DataBind();
    }
--------------------------------------------------------------------------------------------
--------------------------------------------------------------------------------------------

Comments

Popular posts from this blog

ASP.NET MVC - Set custom IIdentity or IPrincipal

Here's how I do it. I decided to use IPrincipal instead of IIdentity because it means I don't have to implement both IIdentity and IPrincipal. Create the interface interface ICustomPrincipal : IPrincipal { int UserId { get ; set ; } string FirstName { get ; set ; } string LastName { get ; set ; } } CustomPrincipal public class CustomPrincipal : ICustomPrincipal { public IIdentity Identity { get ; private set ; } public bool IsInRole ( string role ) { return false ; } public CustomPrincipal ( string email ) { this . Identity = new GenericIdentity ( email ); } public int UserId { get ; set ; } public string FirstName { get ; set ; } public string LastName { get ; set ; } } CustomPrincipalSerializeModel - for serializing custom information into userdata field in FormsAuthenticationTicket object. public class CustomPrincipalSerializeMode...

Validate credit card number with Mod 10 algorithm in C#

Introduction All you know what information contains in your NIC number. But do you know what information contains in the Credit Card Number? Following article provides brief details about what information contain in your credit card and demonstrates to how to validate credit card number using mod 10 (Luhn) algorithms with C#. Background  Card Length   Typically, credit card numbers are all numeric and the length of the credit card number is between 12 digits to 19 digits.  14, 15, 16 digits – Diners Club 15 digits – American Express 13, 16 digits – Visa 16 digits - MasterCard   For more information please refer  http://en.wikipedia.org/wiki/Bank_card_number . Hidden information  Major Industry Identifier (MII)   The first digit of the credit card number is the Major Industry Identifier (MII). It designates the category of the entry which issued the card.     1 and 2 – Airlin...

kendo ui menu dynamic - ASP.NET MVC

Model Class public class DynamicMenu {     public int MenuID { get; set; }     public string MenuName { get; set; }     public int ParentMenuID { get; set; } } Controller Code public ActionResult Menu() {      ViewData["DynamicMenu"] = new List<DynamicMenu> {             new DynamicMenu{ MenuID = 1, MenuName = "Self", ParentMenuID = 0 },             new DynamicMenu{ MenuID = 2, MenuName = "Functional", ParentMenuID = 0  },             new DynamicMenu{ MenuID = 3, MenuName = "Leave", ParentMenuID = 1 },             new DynamicMenu{ MenuID = 4, MenuName = "Leave Application", ParentMenuID = 3 },             new Dynamic...