本文为大家分享了自己写的一个Pager分页组件,WebForm,Mvc都适用,具体内容如下
分页控件其实就是根据链接在页面间传递参数,因为我看到MVC中你可以看到这样传递参数的new {para=val}这种方式传递参数,于是我想到用可以模仿这种传递参数的方式,那就用dynamic来作为参数对象传递。
下面是附上我写的具体的实现的代码
数据处理代码:
1.定义IPagedList接口
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Infrastruction.Pager { public interface IPagedList { int pageIndex { get; set; } int pageSize { get; set; } int totalItemCount { get; set; } int totalPageCount { get; } } }
2.实现IPagedList接口
using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace Infrastruction.Pager { public class PagedList<T> : List<T>, IPagedList { public int pageIndex { get; set; } public int pageSize { get; set; } public int totalItemCount { get; set; } public int totalPageCount { get { return totalItemCount % pageSize == 0 ? (totalItemCount / pageSize) : (totalItemCount / pageSize + 1); } } public PagedList(IEnumerable<T> sources, int pageIndex, int pageSize) { if (sources != null && sources.Any()) { this.AddRange(sources.Skip(pageSize * (pageIndex - 1)).Take(pageSize).ToList()); } this.pageIndex = pageIndex; this.pageSize = pageSize; this.totalItemCount = sources.Count(); } } }
分页标签处理代码:
3.PagerHelper
using Infrastruction.Pager; using System; using System.Collections.Generic; using System.Linq; using System.Reflection; using System.Text; using System.Web; using System.Web.UI; namespace System.Web.UI { public static class PagerHelper { public static string Pager(string url, IPagedList pagedList) { StringBuilder builder = new StringBuilder(); if (pagedList != null) { builder.Append(\"<script type=\'text/javascript\'>\"); builder.Append(\"window.onload = function () {\"); builder.Append(\" var elements = document.getElementById(\'pager\').childNodes;\"); builder.Append(\" for (var i = 0; i < elements.length; i++) {\"); builder.Append(\"var txt = elements[i].innerText || elements[i].textContent;\"); builder.Append(\" if (elements[i].nodeType ==\'1\' && txt == \'\" + pagedList.pageIndex + \"\') {\"); builder.Append(\"elements[i].style.textDecoration = \'underline\';break; } } }\"); builder.Append(\"</script>\"); builder.Append(\"<div id=\'pager\'>\"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"共 {0} 条数据 页次:{1}/{2}\", pagedList.totalItemCount, pagedList.pageIndex, pagedList.totalPageCount, \"上一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\" \"); builder.Append(\" \"); builder.Append(\" \"); if (pagedList.pageIndex > 1 && pagedList.pageIndex <= pagedList.totalPageCount) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, 1, \"首页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, pagedList.pageIndex - 1, \"上一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); } if (pagedList.totalPageCount > 1 && pagedList.totalPageCount <= 10) { for (int i = 1; i <= pagedList.totalPageCount; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } } else if (pagedList.totalPageCount > 10) { if (pagedList.pageIndex < 11) { for (int i = 1; i <= 10; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, 11, \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); } else { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, (pagedList.pageIndex - 6), \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); if (pagedList.pageIndex >= 11 && pagedList.totalPageCount <= pagedList.pageIndex + 5) { for (int i = pagedList.pageIndex - 5; i <= pagedList.totalPageCount; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } } else { for (int i = pagedList.pageIndex - 5; i <= pagedList.pageIndex + 5; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, (pagedList.pageIndex + 6), \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); } } } if (pagedList.pageIndex >= 1 && pagedList.pageIndex < pagedList.totalPageCount) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, pagedList.pageIndex + 1, \"下一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?pageIndex={1}\'>{2}</a>\", url, pagedList.totalPageCount, \"尾页\"); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"</div>\"); } return builder.ToString(); } public static string Pager(string url, IPagedList pagedList, dynamic objAttr) { StringBuilder builder = new StringBuilder(); if (pagedList != null) { builder.Append(\"<script type=\'text/javascript\'>\"); builder.Append(\"window.onload = function () {\"); builder.Append(\" var elements = document.getElementById(\'pager\').childNodes;\"); builder.Append(\" for (var i = 0; i < elements.length; i++) {\"); builder.Append(\"var txt = elements[i].innerText || elements[i].textContent;\"); builder.Append(\" if (elements[i].nodeType ==\'1\' && txt == \'\" + pagedList.pageIndex + \"\') {\"); builder.Append(\"elements[i].style.textDecoration = \'underline\';break; } } }\"); builder.Append(\"</script>\"); string paras = \"\"; PropertyInfo[] infos = objAttr.GetType().GetProperties(); if (infos != null && infos.Any()) { foreach (var item in infos) { paras += string.Format(\"{0}={1}\", item.Name, item.GetValue(objAttr, null)); paras += \"&\"; } } paras = paras + \"pageIndex=\"; builder.Append(\"<div id=\'pager\'>\"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"共 {0} 条数据 页次:{1}/{2}\", pagedList.totalItemCount, pagedList.pageIndex, pagedList.totalPageCount, \"上一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\" \"); builder.Append(\" \"); builder.Append(\" \"); if (pagedList.pageIndex > 1 && pagedList.pageIndex <= pagedList.totalPageCount) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + 1, \"首页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + (pagedList.pageIndex - 1), \"上一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); } if (pagedList.totalPageCount > 1 && pagedList.totalPageCount <= 10) { for (int i = 1; i <= pagedList.totalPageCount; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } } else if (pagedList.totalPageCount > 10) { if (pagedList.pageIndex < 11) { for (int i = 1; i <= 10; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + 11, \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); } else { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + (pagedList.pageIndex - 6), \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); if (pagedList.pageIndex >= 11 && pagedList.totalPageCount <= pagedList.pageIndex + 5) { for (int i = pagedList.pageIndex - 5; i <= pagedList.totalPageCount; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } } else { for (int i = pagedList.pageIndex - 5; i <= pagedList.pageIndex + 5; i++) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + i, i); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + (pagedList.pageIndex + 6), \"...\"); builder.Append(\"</span>\"); builder.Append(\" \"); } } } if (pagedList.pageIndex >= 1 && pagedList.pageIndex < pagedList.totalPageCount) { builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + (pagedList.pageIndex + 1), \"下一页\"); builder.Append(\"</span>\"); builder.Append(\" \"); builder.Append(\"<span class=\'p\'>\"); builder.AppendFormat(\"<a href=\'{0}?{1}\'>{2}</a>\", url, paras + pagedList.totalPageCount, \"尾页\"); builder.Append(\"</span>\"); builder.Append(\" \"); } builder.Append(\"</div>\"); } return builder.ToString(); } } }
4. PagerLinqExtension( 基于linq的扩展)
using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; using System.Web; namespace Infrastruction.Pager { public static class PagerLinqExtension { public static PagedList<T> ToPagedList<T>(this IQueryable<T> source, int pageIndex, int pageSize) { return new PagedList<T>(source, pageIndex, pageSize); } } }
调用方法
1.Webform调用: <%=PagerHelper.Pager(\"Products.aspx\", pageList, new { cid=Cid})%> 或者用literal在后台绑定也行
2.Mvc调用:
需要扩展一下方法
namespace System.Web.Mvc.Html { public static class HtmlExtension { public static IHtmlString Pager(this HtmlHelper helper, string url, IPagedList pagedList) { return helper.Raw(PagerHelper.Pager(url, pagedList)); } public static IHtmlString Pager(this HtmlHelper helper, string url, IPagedList pagedList, dynamic objAttr) { return helper.Raw(PagerHelper.Pager(url, pagedList, objAttr)); } } }
然后页面调用@Html.Pager(\"Products.aspx\", pageList, new { cid=Cid,......})
全部的代码都在上面,希望大家认真学习,对大家学习使用分页控件有所帮助。
本文地址:https://www.stayed.cn/item/13359
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我