• .net mvc 分页


    1、分页实体类

        public class PageDto
        {
            public int PageIndex { get; set; }
            public int PageSize { get; set; }
            public int PageCount { get; set; }
            public int TotalCount { get; set; }
        }

    后端代码

            public async Task<IActionResult> Index()
            {
                var page = HttpContext.Request.Query["page"].ToString();
                var pageSize = HttpContext.Request.Query["pageSize"].ToString();
    
                var searchDto = new FileSearchDto()
                {
                    PageIndex = string.IsNullOrWhiteSpace(page) ? 1 : Convert.ToInt32(page),
                    PageSize = string.IsNullOrWhiteSpace(pageSize) ? 5 : Convert.ToInt32(pageSize)
                };
    
                var results = await _service.GetPageList(searchDto);
                var model = new FileListViewModel() { Results = results };
                return View(model);
            }
    

      

    2、视图

    @using System.Text;
    @model BaseService.PageDto
    
    @if (Model.TotalCount > Model.PageSize)
    {
        var controller = Url.ActionContext.RouteData.Values["controller"];
        var action = Url.ActionContext.RouteData.Values["action"];
        var url = "/" + controller + "/" + action;
        var querys = Url.ActionContext.HttpContext.Request.Query;
        StringBuilder sb = new StringBuilder();
        sb.AppendFormat("/{0}/{1}?", controller, action);
        if (querys != null && querys.Count > 0)
        {
            foreach (var item in querys)
            {
                if (!item.Key.Equals("page"))
                {
                    sb.AppendFormat("{0}={1}", item.Key, item.Value);
                    sb.Append("&");
                }
            }
        }
        sb.Append("page");
    
        url = sb.ToString();
    
        <div style="position:fixed;bottom:-15px;text-align:center;84%">
            <ul class="pagination">
                <h5 class="pull-left">显示第 @((Model.PageIndex - 1) * Model.PageSize + 1) - @(Model.PageIndex * Model.PageSize > Model.TotalCount ? Model.TotalCount : Model.PageIndex * Model.PageSize) 条记录,共 @Model.TotalCount 条记录</h5>
                @if (Model.PageIndex > 1)
                {
                    <li><a href="@url=1" title="首页"><i class="fa fa-chevron-left"></i></a></li>
                }
                else
                {
                    <li class="disabled"><a href="javascript:;" title="首页"><i class="fa fa-chevron-left"></i></a></li>
    
                }
                @{
                    int pagesizeshow = 6;//每次显示分页按钮数量
                    int pagemin = Model.PageIndex - (int)(pagesizeshow / 2);
                    int pagemax = Model.PageIndex + (int)(pagesizeshow / 2);
                    if (Model.PageIndex + (int)(pagesizeshow / 2) >= Model.PageCount)
                    {
                        pagemin = Model.PageCount - (int)(pagesizeshow / 2);
                        pagemax = Model.PageCount;
                    }
                    if (Model.PageIndex <= (int)(pagesizeshow / 2))
                    {
                        pagemin = 1;
                        pagemax = pagesizeshow;
                    }
                    if (pagemin <= 0) { pagemin = 1; }
                    if (pagemax >= Model.PageCount) { pagemax = Model.PageCount; }
                    if (pagemin + pagesizeshow >= Model.PageCount) { pagemin = (Model.PageCount - pagesizeshow) >= 1 ? (Model.PageCount - pagesizeshow) : pagemin; }
    
                    if (pagemin == pagemax)
                    {
                        <li><a href="@url=@pagemin">@pagemin</a></li>
                    }
                    else
                    {
                        for (int i = pagemin; i <= pagemax; i++)
                        {
                            <li @if (Model.PageIndex == i) { <text> class="active" </text> }><a href="@url=@i">@i</a></li>
                        }
                    }
                }
    
                @if (Model.PageIndex < Model.PageCount)
                {
                    <li><a href="@url=@Model.PageCount" title="尾页"><i class="fa fa-chevron-right"></i></a></li>
                }
                else
                {
                    <li class="disabled"><a href="javascript:;" title="尾页"><i class="fa fa-chevron-right"></i></a></li>
                }
            </ul>
        </div>
    }
    

    3、调用

       @Html.Partial("~/Views/Pager/Create.cshtml", Model.Results.Page)

  • 相关阅读:
    redis的5种数据结构和基本操作
    kafka架构、基本术语、消息存储结构
    kafka基本概念和hello world搭建
    kafka安装
    【Android-NetWork】 判断是否连接网络,判断网络连接方式
    【计算机-虚拟wifi】Win7虚拟wifi设置
    【Andriod-AlertDialog控件】 弹出对话框AlertDialog用法
    【Winform-自定义控件】ImageButton 支持鼠标正常、悬停、按下更改图片,支持文本
    【Wince-自定义控件】ImageButton 带图片、文字
    【Winform-自定义控件】一个自定义的进度条
  • 原文地址:https://www.cnblogs.com/lizhenhong/p/9151815.html
Copyright © 2020-2023  润新知