core mvc 分页

看了下XPAGE感觉还是用的不太爽,自己写了个,不处理数据,只根据参数生成分页的html代码,样式是bootstrap的,需要的小伙伴拿走吧。

public static IHtmlContent Pager(this IHtmlHelper html, long totalCount, int pageSize, string pageStr)
        {
            if (totalCount < 1) return new HtmlString(string.Empty);

            var totalPages = (int)Math.Ceiling(totalCount / (double)pageSize); //总页数

            var dicRoute = html.ViewContext.RouteData.Values;
            var strQuery = html.ViewContext.HttpContext.Request.Query;
            int pageIndex;
            if (dicRoute.ContainsKey(pageStr))
            {
                if (!int.TryParse(dicRoute[pageStr].ToString(), out pageIndex)) pageIndex = 1;
            }
            else
            {
                if (!int.TryParse(strQuery[pageStr].ToString(), out pageIndex)) pageIndex = 1;
            }

            if (pageIndex < 1) pageIndex = 1;
            if (pageIndex > totalPages) pageIndex = totalPages;

            foreach (var key in dicRoute.Keys)
            {
                if (string.IsNullOrEmpty(key) || !strQuery.ContainsKey(key)) continue;
                if (!strQuery.TryGetValue(key, out var values)) continue;
                if (values.Count == 1 && !string.IsNullOrEmpty(values))
                {
                    dicRoute[key] = strQuery[key];
                }
            }

            var sbOut = new StringBuilder();
            sbOut.Append("<nav aria-label=\"Page navigation\">");
            sbOut.Append("<ul class=\"pagination\">");
            if (totalPages > 1)
            {
                sbOut.Append("<li");
                sbOut.Append(pageIndex == 1 ? "  class=\"disabled\">" : ">");
                dicRoute[pageStr] = 1;
                sbOut.Append(pageIndex == 1 ? "<a>首页</a>" : GetString(html.RouteLink("首页", dicRoute)));
                sbOut.Append("</li>");


                var pre = pageIndex - 1;
                if (pre < 1) pre = 1;
                sbOut.Append("<li");
                sbOut.Append(pageIndex == 1 ? "  class=\"disabled\">" : ">");
                dicRoute[pageStr] = pre;
                sbOut.Append(pageIndex == 1 ? "<a>上一页</a>" : GetString(html.RouteLink("上一页", dicRoute)));
                sbOut.Append("</li>");


                var nex = pageIndex + 1;
                if (nex > totalPages) nex = totalPages;
                sbOut.Append("<li");
                sbOut.Append(pageIndex == totalPages ? "  class=\"disabled\">" : ">");
                dicRoute[pageStr] = nex;
                sbOut.Append(pageIndex == totalPages ? "<a>下一页</a>" : GetString(html.RouteLink("下一页", dicRoute)));
                sbOut.Append("</li>");

                sbOut.Append("<li");
                sbOut.Append(pageIndex == totalPages ? "  class=\"disabled\">" : ">");
                dicRoute[pageStr] = totalPages;
                sbOut.Append(pageIndex == totalPages ? "<a>尾页</a>" : GetString(html.RouteLink("尾页", dicRoute)));
                sbOut.Append("</li>");
            }

            sbOut.AppendFormat("<li><a>共{0}条数据</a></li>", totalCount);

            sbOut.Append("</ul>");
            sbOut.Append("</nav>");


            return new HtmlString(sbOut.ToString());

        }

说明下,totalCount是总条数,pageSize是每页条数,pageStr是页参数的 key 如:http://123.com/?page=4   pageStr就是 page

使用如下

@Html.Pager(10, 1, "page")

 以上代码中的 GetString 方法请阅读第一篇文章

 

totalcount     详细 X
网络释义
totalcount: 总记录
TotalCount Integer: 伸缩规则总数
TotalCount String: 列表条条目数

pager   ['peɪdʒə]   pager&type=1 详细 X
基本翻译
n. 寻呼机,呼机
n. (Pager)人名;(德)帕格
网络释义
pager: 传呼机
Cowhide Pager: 牛皮纸
numeric pager: 数字寻呼机

转载于:https://www.cnblogs.com/jzz228/p/11083557.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值