Как добавить динамическую подкачку в виде таблицы с помощью asp.net

#c# #asp.net #gridview #datatable

#c# #asp.net #gridview #datatable

Вопрос:

Я хочу отобразить только 10 записей на одной странице, затем остальные записи, которые он должен отображать на второй и третьей страницах. Когда пользователь нажимает 2, он должен отображать следующие 10 записей. Здесь я динамически ввожу данные в gridview.

это мой код

 protected void Page_Load(object sender, EventArgs e)
    {
        // data load to grid view
        loadDataTable();

    }

    private void loadDataTable()
    {
        DataSet ds = new DataSet();
        DataTable dt;
        DataRow dr;

        DataColumn date;
        DataColumn designation;
        DataColumn experience;
        DataColumn location;
        DataColumn nationality;
        DataColumn details;

        dt = new DataTable();

        date = new DataColumn("Date");
        designation = new DataColumn("Designation");
        experience = new DataColumn("Experience");
        location = new DataColumn("Location");
        nationality = new DataColumn("Nationality");
        details = new DataColumn("Details");

        dt.Columns.Add(date);
        dt.Columns.Add(designation);
        dt.Columns.Add(experience);
        dt.Columns.Add(location);
        dt.Columns.Add(nationality);
        dt.Columns.Add(details);

        string cs = ConfigurationManager.ConnectionStrings["connectionStringDb"].ConnectionString;
        using (SqlConnection con = new SqlConnection(cs))
        {
            SqlCommand cmd = new SqlCommand("spGetJobPost_tb",con);

            cmd.CommandType = CommandType.StoredProcedure;

            con.Open();
            SqlDataReader rd = cmd.ExecuteReader();

            while(rd.Read())
            {
                dr = dt.NewRow();
                //DateTime dat = DateTime.ParseExact(rd["Date"].ToString(),"dd/MM/yyyy",null);
                string dates= ((DateTime)rd["Date"]).ToString("dd-MM-yyyy");
                dr["Date"] = dates;
                dr["Designation"] = rd["job_title"].ToString();
                dr["Experience"] = rd["experience"].ToString();
                dr["Location"] = rd["location"].ToString();
                dr["Nationality"] = rd["nationality"].ToString();
                dr["Details"] = "<a href='Details.aspx?id=" rd["Id"].ToString() "' target='_blank'>View Details</a>";

                dt.Rows.Add(dr);
            }
        }
        ds.Tables.Add(dt);
        GridView1.DataSource = ds.Tables[0];
        GridView1.DataBind();
    }
  

asp.net код

 <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False">
                        <Columns>
                            <asp:BoundField DataField="Date" HeaderText="Date" />
                            <asp:BoundField DataField="Designation" HeaderText="Designation" />
                            <asp:BoundField DataField="Experience" HeaderText="Experience" />
                            <asp:BoundField DataField="Location" HeaderText="Location" />
                            <asp:BoundField DataField="Nationality" HeaderText="Nationality" />
                            <asp:BoundField HeaderText="Details" HtmlEncode="false" DataField="Details" />
                        </Columns>

                    </asp:GridView>
  

Я новичок в представлении сетки и asp.net .

Комментарии:

1. Вы можете использовать встроенный GridView paging..c-sharpcorner.com/uploadfile/rohatash /…

2. @Anant Dabhi Это работает, спасибо

Ответ №1:

вы можете использовать AllowPaging и PageSize для записей на странице в соответствии с приведенным примером, спасибо

 <asp:GridView runat="server" ID="studentsGrid" AllowPaging="true" PageSize="4">