分页组件

实现效果如图:

1.新建一个类:PagerHelper,方法名称:Pager,实现代码:

public class PagerHelper
{
    /// <summary>
    /// 生成页码的html
    /// </summary>
    /// <param name="urlFormat">超链接的格式。/Home?pagenum={pagenum}。地址中用{pagenum}做为当前页码的占位符</param>
    /// <param name="totalSize">总数据条数</param>
    /// <param name="pageSize">每页多少条数据 </param>
    /// <param name="currentPage">当前页的页码</param>
    /// <returns></returns>
    public static RawString Pager(string urlFormat, long totalSize,long pageSize, long currentPage)
    {
        StringBuilder sb = new StringBuilder();
        //总页数
        long totalPageCount = (long)Math.Ceiling((totalSize * 1.0f) / (pageSize * 1.0f));
        //在当前页面前后各最多显示5个页码
        int currentPageNum = 2;
        if (currentPage == 1 || currentPage == totalPageCount)
        {
            currentPageNum = 4;
        }
        else if (currentPage == 2 || currentPage == totalPageCount - 1)
        {
            currentPageNum = 3;
        }
        //计算页码条中第一条的页码
        long firstPageNum = Math.Max(currentPage - currentPageNum, 1);
        //计算页码条中最后一条的页码
        long lastPageNum = Math.Min(currentPage + currentPageNum, totalPageCount);
        sb.Append("<ul class='pagination col-md-12'>");
        if (currentPage > 1)
        {
            sb.AppendLine("<li><a href='" + urlFormat.Replace("{pagenum}", "1") + "'>首页</a></li>");
            sb.AppendLine("<li><a href='" + urlFormat.Replace("{pagenum}", (currentPage - 1).ToString()) + "'>上页</a></li>");
        }
        else
        {
            sb.AppendLine("<li><a>首页</a></li>");
            sb.AppendLine("<li><a>上页</a></li>");
        }
        for (long i = firstPageNum; i <= lastPageNum; i++)
        {
            string url = urlFormat.Replace("{pagenum}", i.ToString());
            if (i == currentPage)
            {
                sb.Append("<li class='active'><a>" + i + "</a></li>");
            }
            else
            {
                sb.Append("<li><a href='" + url + "'>" + i + "</a></li>");
            }
        }
        if (currentPage < totalPageCount)
        {
            sb.AppendLine("<li><a href='" + urlFormat.Replace("{pagenum}", (currentPage + 1).ToString()) + "'>下页</a></li>");
            sb.AppendLine("<li><a href='" + urlFormat.Replace("{pagenum}", totalPageCount.ToString()) + "'>末页</a></li>");
        }
        else
        {
            sb.AppendLine("<li><a>下页</a></li>");
            sb.AppendLine("<li><a>末页</a></li>");
        }
        sb.Append("</ul>");
        return new RawString(sb.ToString());
    }
}

2.css样式:

<style type="text/css">
    .pagination {
        display: inline-block;
        padding-left: 0;
        margin: 20px 0;
        border-radius: 4px;
    }

    .pagination > li {
        display: inline;
    }

    .pagination > li > a,
    .pagination > li > span {
        position: relative;
        float: left;
        padding: 3px 10px;
        margin-left: -1px;
        line-height: 1.42857143;
        color: #337ab7;
        text-decoration: none;
        background-color: #fff;
        border: 1px solid #ddd;
    }

    .pagination > li:first-child > a,
    .pagination > li:first-child > span {
        margin-left: 0;
        border-top-left-radius: 4px;
        border-bottom-left-radius: 4px;
    }

    .pagination > li:last-child > a,
    .pagination > li:last-child > span {
        border-top-right-radius: 4px;
        border-bottom-right-radius: 4px;
    }

    .pagination > li > a:hover,
    .pagination > li > span:hover,
    .pagination > li > a:focus,
    .pagination > li > span:focus {
        z-index: 3;
        color: #23527c;
        background-color: #eee;
        border-color: #ddd;
    }

    .pagination > .active > a,
    .pagination > .active > span,
    .pagination > .active > a:hover,
    .pagination > .active > span:hover,
    .pagination > .active > a:focus,
    .pagination > .active > span:focus {
        z-index: 2;
        color: #fff;
        cursor: default;
        background-color: #337ab7;
        border-color: #337ab7;
    }

    .pagination > .disabled > span,
    .pagination > .disabled > span:hover,
    .pagination > .disabled > span:focus,
    .pagination > .disabled > a,
    .pagination > .disabled > a:hover,
    .pagination > .disabled > a:focus {
        color: #777;
        cursor: not-allowed;
        background-color: #fff;
        border-color: #ddd;
    }

    .pagination-lg > li > a,
    .pagination-lg > li > span {
        padding: 10px 16px;
        font-size: 18px;
        line-height: 1.3333333;
    }

    .pagination-lg > li:first-child > a,
    .pagination-lg > li:first-child > span {
        border-top-left-radius: 6px;
        border-bottom-left-radius: 6px;
    }

    .pagination-lg > li:last-child > a,
    .pagination-lg > li:last-child > span {
        border-top-right-radius: 6px;
        border-bottom-right-radius: 6px;
    }

    .pagination-sm > li > a,
    .pagination-sm > li > span {
        padding: 5px 10px;
        font-size: 12px;
        line-height: 1.5;
    }

    .pagination-sm > li:first-child > a,
    .pagination-sm > li:first-child > span {
        border-top-left-radius: 3px;
        border-bottom-left-radius: 3px;
    }

    .pagination-sm > li:last-child > a,
    .pagination-sm > li:last-child > span {
        border-top-right-radius: 3px;
        border-bottom-right-radius: 3px;
    }
</style>

3.调用:

@Html.Raw(Tools.PagerHelper.Pager("/Home?pn={pagenum}", Model.TotalSize, 10, Model.PageNum))

 

posted @ 2017-03-19 17:57  黄者之风  阅读(313)  评论(0编辑  收藏  举报