asp.net gridview分页:第一页 下一页 1 2 3 4 上一页 最末页

当我们需要在asp.net网站中实现数据分页展示的功能时,可以使用GridView控件来实现。下面是实现asp.net GridView 分页展示的完整攻略。

安装PagedList.Mvc

我们可以通过Nuget安装PagedList.Mvc,在Manage NuGet Packages界面搜索PagedList.Mvc进行安装。这是一个非常常用的分页库,可以大大减轻分页的开发难度。

安装完成后,我们可以在代码中使用PagedList.Mvc的相关方法,实现快速方便的分页功能。

绑定数据源到GridView控件

在ASP.NET webform代码中,我们可以使用GridView控件来展示数据库中的数据。GridView控件可以与数据源进行绑定,并在网站中将数据以表格形式进行展示。

以下是GridView与数据源进行绑定的示例代码:

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" DataSourceID="SqlDataSource1">
            <Columns>
                <asp:BoundField DataField="ProductID" HeaderText="ProductID" SortExpression="ProductID" />
                <asp:BoundField DataField="ProductName" HeaderText="ProductName" SortExpression="ProductName" />
                <asp:BoundField DataField="CategoryName" HeaderText="CategoryName" SortExpression="CategoryName" />
                <asp:BoundField DataField="UnitPrice" HeaderText="UnitPrice" SortExpression="UnitPrice" />
            </Columns>
        </asp:GridView>

// 数据源SQLDataSource1
<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:NorthwindConnectionString %>" SelectCommand="SELECT [ProductID], [ProductName], [CategoryName], [UnitPrice] FROM [ProductsWithCategories]"></asp:SqlDataSource>

GridView分页

下面是使用PagedList.Mvc库实现GridView分页的示例代码:

  1. 首先,在Controller中查询数据:
public ActionResult Index(string sortOrder, string searchString, int? page)
{
    ViewBag.NameSortParm = String.IsNullOrEmpty(sortOrder) ? "name_desc" : "";
    ViewBag.DateSortParm = sortOrder == "Date" ? "date_desc" : "Date";
    var students = from s in db.Students
                   select s;
    if (!String.IsNullOrEmpty(searchString))
    {
        students = students.Where(s => s.LastName.Contains(searchString)
                               || s.FirstMidName.Contains(searchString));
    }
    switch (sortOrder)
    {
        case "name_desc":
            students = students.OrderByDescending(s => s.LastName);
            break;
        case "Date":
            students = students.OrderBy(s => s.EnrollmentDate);
            break;
        case "date_desc":
            students = students.OrderByDescending(s => s.EnrollmentDate);
            break;
        default:
            students = students.OrderBy(s => s.LastName);
            break;
    }
    int pageSize = 3;
    int pageNumber = (page ?? 1);
    return View(students.ToPagedList(pageNumber, pageSize));
}
  1. 在View中分页展示数据,使用PagedList.Mvc的分页方法:
@{
    ViewBag.Title = "Students";
}
<h2>Students</h2>

<p>
    @Html.ActionLink("Create New", "Create")
</p>

@using (Html.BeginForm())
{
    <p>
        Find by name: @Html.TextBox("SearchString") <input type="submit" value="Search" />
    </p>
}
<table class="table">
    <tr>
        <th>
            @Html.ActionLink("Name", "Index", new { sortOrder = ViewBag.NameSortParm })
        </th>
        <th>
            @Html.ActionLink("Enrollment Date", "Index", new { sortOrder = ViewBag.DateSortParm })
        </th>
        <th></th>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.LastName) , @Html.DisplayFor(modelItem => item.FirstMidName)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.EnrollmentDate)
        </td>
        <td>
            @Html.ActionLink("Edit", "Edit", new { id=item.ID }) |
            @Html.ActionLink("Details", "Details", new { id=item.ID }) |
            @Html.ActionLink("Delete", "Delete", new { id=item.ID })
        </td>
    </tr>
}

</table>

<div>
    Page @(Model.PageCount < Model.PageNumber ? 0 : Model.PageNumber) of @Model.PageCount

    @Html.PagedListPager(Model, page => Url.Action("Index", 
        new { page, sortOrder = ViewBag.CurrentSort, searchString = ViewBag.CurrentFilter }))
</div>

总结

通过上述步骤,我们就可以简单轻松的实现asp.net GridView分页功能。使用PagedList.Mvc库可以让我们更加方便地实现分页,提高开发效率。同时,在实现GridView和数据源的绑定时,我们也可以根据具体需求灵活设置展示效果。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:asp.net gridview分页:第一页 下一页 1 2 3 4 上一页 最末页 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • 16个最流行的JavaScript框架[推荐]

    16个最流行的JavaScript框架[推荐]攻略 介绍 JavaScript框架可以帮助开发者更加高效地创建Web应用程序。在这篇攻略中,我们将介绍16个最流行的JavaScript框架,这些框架功能各异,可以满足不同开发需求。在选择JavaScript框架时,我们建议开发者先考虑项目的需求和特点。以下是我们推荐的16个JavaScript框架: Angu…

    JavaScript 2023年5月18日
    00
  • 在javascript中随机数 math random如何生成指定范围数值的随机数

    首先需要了解 Math.random() 方法可以生成一个在0(包含0)到1(不包括1)之间的一个伪随机数。要生成指定范围内的随机数,需要通过一些计算和转换来实现。以下是一些可能的做法: 做法一:生成任意两数之间的随机数 可以先生成一个在0到1之间的随机小数,然后将其乘以两个数的范围,再加上较小的数,从而实现生成任意两数之间的随机数。 function ra…

    JavaScript 2023年6月10日
    00
  • PHP中CURL的几个经典应用实例

    下面是详细讲解“PHP中CURL的几个经典应用实例”的完整攻略。 1. 什么是CURL? CURL是一种在网络通信中使用的工具,它支持多种网络协议,可以用来HTTP、FTP、SMTP等服务的客户端程序。在PHP中,可以使用CURL库来实现与远程服务器的数据传输。 2. 安装CURL扩展 在使用PHP中的CURL扩展之前,需要先安装CURL扩展,以确保PHP支…

    JavaScript 2023年6月11日
    00
  • javascript同步Import,同步调用外部js的方法

    JavaScript同步Import是一种将外部JavaScript文件同步导入到当前JavaScript文件中的方法。这种方法可以让外部JavaScript文件中的函数和变量永久地集成到当前JavaScript文件中。以下是使用该方法的完整攻略: 1. 创建一个外部的JavaScript文件 首先,您需要在与当前JavaScript文件相同的目录中创建一个…

    JavaScript 2023年6月11日
    00
  • 轻轻松松学JS调试(不下载任何工具)

    下面我来详细讲解“轻轻松松学JS调试(不下载任何工具)”的完整攻略。 调试JS代码的原理 在开始学习调试JS代码之前,先了解一下调试的原理。当JS代码出现错误时,浏览器会在控制台输出错误信息,我们可以通过错误信息来判断代码出错的位置和原因。因此,掌握控制台的使用是非常重要的。 使用console输出信息 console是调试中非常重要的一个工具,常用于输出变…

    JavaScript 2023年6月11日
    00
  • OpenTiny 跨端、跨框架组件库升级TypeScript,10万行代码重获新生

    摘要:一份精心准备的《JS项目改造TS指南》文档供大家参考,顺便介绍TS 基础知识和 TS 在 Vue 中的实践。 本文分享自华为云社区《历史性的时刻!OpenTiny 跨端、跨框架组件库正式升级 TypeScript,10 万行代码重获新生!》,作者:Kagol。 根据 The Software House 发布的《2022 前端开发市场状态调查报告》数据…

    JavaScript 2023年4月17日
    00
  • JS数组方法concat()用法实例分析

    JS数组方法concat()用法实例分析 简介 JavaScript中的数组方法concat()可以将多个数组(或值)连接成一个新数组,并返回该新数组。原数组不会被改变。该方法不会改变原始数组,而是返回一个新数组。 该方法是 JavaScript 的一个重要工具,可以用在很多场合。比如: 连接不同的数组,创建一个新的数组。 将一个或多个值添加到数组中。 将数…

    JavaScript 2023年5月27日
    00
  • 不刷新网页就能链接新的js文件方法总结

    “不刷新网页就能链接新的JS文件”是通过AJAX技术实现的。基本流程如下: 使用XMLHttpRequest对象定义AJAX请求。 发送AJAX请求到服务器,获取JS文件的内容。 将新的JS代码注入到页面中。 以下是详细的实现步骤: 1. 定义AJAX请求 function loadScript(url, callback) { var xhr = new …

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部