MVC数据库数据分页显示

本文介绍了一种在ASP.NET MVC应用中实现分页的方法。通过定义一个泛型分页帮助器类,可以轻松地对数据库查询结果进行分页处理,并在视图中展示分页导航链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先从数据库获取数据

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using mvctest.Models;

namespace mvctest.customclass
{
    
    public class getdataresource
    {
        public List<student> gd()
        {
            Model1 db=new Model1();
            var q = from p in db.Students select p;
            return q.ToList();
        }
    }
}

分页代码:网上复制的

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace mvctest
{
   // 分页器Code

 public class PagingHelper<T>
    {
        //分页数据源
        public IEnumerable<T> DataSource { get; private set; }
        //每页显示记录的数量
        public int PageSize { get; private set; }
        //当前页数
        public int PageIndex { get; set; }
        //分页总页数
        public int PageCount { get; private set; }

        //是否有前一页
        public bool HasPrev { get { return PageIndex > 1; } }
        //是否有下一页
        public bool HasNext { get { return PageIndex < PageCount; } }
        //构造函数
        public PagingHelper(int pageSize, IEnumerable<T> dataSource)
        {
            this.PageSize = pageSize > 1 ? pageSize : 1;
            this.DataSource = dataSource;
            PageCount = (int)Math.Ceiling(dataSource.Count() / (double)pageSize);
        }
        //获取当前页数据
        public IEnumerable<T> GetPagingData()
        {
            return DataSource.Skip((PageIndex - 1) * PageSize).Take(PageSize);
        }
    }
}

控制器中的代码

public ActionResult pagehelp(int pageIndex = 1)
        {
            
            getdataresource gd=new getdataresource();
            PagingHelper<student> StudentPaging = new PagingHelper<student>(3, gd.gd());
            StudentPaging.PageIndex = pageIndex;//指定当前页
            return View(StudentPaging);//返回分页器实例到视图
        }

对应视图

@using mvctest.Models
@using mvctest.customclass
@model mvctest.PagingHelper<student>


@{
    ViewBag.Title = "Pagehelper";
}
<h2>Index</h2>
@foreach (var Data in Model.GetPagingData())
{
    <p>ID:@Data.id Name:@Data.name</p>
}
<p>
    @if (Model.HasPrev)
    {
        <a href="@Url.Action("pagehelp", "test", new { pageIndex = Model.PageIndex - 1 })">上一页</a>
    }
    else
    {
        <em style="color:Gray">上一页</em>
    }
    @if (Model.HasNext)
    {
        <a href="@Url.Action("pagehelp", "test", new { pageIndex = Model.PageIndex + 1 })">下一页</a>
    }
    else
    {
        <em style="color:Gray">下一页</em>
    }
</p>

 

转载于:https://www.cnblogs.com/lovejunjuan/p/4680344.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值