• asp.net core下一个简单的分页技术


    在做web应用的时候免不了要对数据进行分页,我最近在做asp.net core的开发的时候就遇到了这个需求,现在简单的记录一下:

     public class PaginatedList<T>:List<T>
        {
            /// <summary>
            /// 当前页
            /// </summary>
             public int PageIndex { get; set; }
            //总页面数
            public int TotalPages { get; set; }
    
    
            public PaginatedList(List<T> items, int count, int pageIndex, int pageSize)
            {
                PageIndex = pageIndex;
    
                TotalPages = (int)Math.Ceiling(count / (decimal)pageSize);
    
                this.AddRange(items);
            }
            /// <summary>
            /// 判断是否有上一页
            /// </summary>
            public bool HasPreViousPage => (PageIndex > 1);
            /// <summary>
            /// 判断是否有下一页
            /// </summary>
            public bool HasNextPage => PageIndex < TotalPages;
            /// <summary>
            /// 创建分页
            /// </summary>
            /// <param name="source">实体信息</param>
            /// <param name="pageIndex">当前页</param>
            /// <param name="pageSize">当前页数据条数</param>
            /// <returns></returns>
            public static async Task<PaginatedList<T>> CreatepagingAsync(IQueryable<T> source,int pageIndex,int pageSize)
            {
                //返回实体总条数
                var count = await source.CountAsync();
    
                var items = await source.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToListAsync();
    
          var dtos=new PaginatedList<T>(items,count,pageIndex,pageSize);
                return dtos;
            }
    
    
        }

    主要的知识点:

    ①这个类表示一个分页,将与分页有关的内容集成到单个类中,符合单一职责原则

    ②PageIndex记录当前页,TotalPages记录总的页数,在构造函数执行的时候,会传入必要的参数来初始化这些字段,构造函数的方法签名为(List<T> items, int count, int pageIndex, int pageSize)不难看出,传入的pageindex参数来初始化当前页,这个pageindex参数肯定是由页面来传入的,pageSize是自定义的一个数据,你想让一个页面显示多少条记录,就定义成多少。还有一个List<T>类型的item,由这个传入的参数来确定item的总条数(item.Count()),然后由了总的条数和每页的条数就可以得出总的页数。

    ③在CreatepagingAsync这个方法中会返回一个构造好的分页类。具体看代码注释

  • 相关阅读:
    CSS3 animation 属性
    关于shortcut icon和icon代码的区别介绍
    用js判断一个复选框是否被选中
    今天开始,走不一样的路
    JavaScript 中的对象
    (已转)Linux基础第七章 线程
    (已转)C++知识图谱
    Linux基础 文件和目录
    (已转)Linux基础第六章 信号
    Linux第四章 进程
  • 原文地址:https://www.cnblogs.com/pangjianxin/p/8024811.html
Copyright © 2020-2023  润新知