一個支持普通分頁和綜合分頁的MVC分頁Helper
本人寫的一個分頁Helper,支持普通分頁(也就是,首頁、上一頁、下一頁、末頁等),綜合分頁(普通分頁和數(shù)字分頁的綜合)。
下面是分頁效果:
分頁代碼:
PagerHelper.cs
using System.Collections.Generic; using System.Collections.Specialized; using System.Linq; using System.Web; using System.Text; using System.Web.Mvc; using System.Web.Routing; using System.Data.Objects.DataClasses; namespace System.Web.Mvc { public static class PagerHelper { /// <summary> /// 分頁 /// </summary> /// <param name="helper"></param> /// <param name="id">分頁id</param> /// <param name="currentPageIndex">當前頁</param> /// <param name="pageSize">分頁尺寸</param> /// <param name="recordCount">記錄總數(shù)</param> /// <param name="htmlAttributes">分頁頭標簽屬性</param> /// <param name="className">分頁樣式</param> /// <param name="mode">分頁模式</param> /// <returns></returns> public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount, object htmlAttributes, string className,PageMode mode) { TagBuilder builder = new TagBuilder("table"); builder.IdAttributeDotReplacement = "_"; builder.GenerateId(id); builder.AddCssClass(className); builder.MergeAttributes(new RouteValueDictionary(htmlAttributes)); builder.InnerHtml = GetNormalPage(currentPageIndex, pageSize, recordCount,mode); return builder.ToString(); } /// <summary> /// 分頁 /// </summary> /// <param name="helper"></param> /// <param name="id">分頁id</param> /// <param name="currentPageIndex">當前頁</param> /// <param name="pageSize">分頁尺寸</param> /// <param name="recordCount">記錄總數(shù)</param> /// <param name="className">分頁樣式</param> /// <returns></returns> public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount, string className) { return Pager(helper, id, currentPageIndex, pageSize, recordCount, null, className,PageMode.Normal); } /// <summary> /// 分頁 /// </summary> /// <param name="helper"></param> /// <param name="id">分頁id</param> /// <param name="currentPageIndex">當前頁</param> /// <param name="pageSize">分頁尺寸</param> /// <param name="recordCount">記錄總數(shù)</param> /// <returns></returns> public static string Pager(this HtmlHelper helper,string id,int currentPageIndex,int pageSize,int recordCount) { return Pager(helper, id, currentPageIndex, pageSize, recordCount,null); } /// <summary> /// 分頁 /// </summary> /// <param name="helper"></param> /// <param name="id">分頁id</param> /// <param name="currentPageIndex">當前頁</param> /// <param name="pageSize">分頁尺寸</param> /// <param name="recordCount">記錄總數(shù)</param> /// <param name="mode">分頁模式</param> /// <returns></returns> public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount,PageMode mode) { return Pager(helper, id, currentPageIndex, pageSize, recordCount, null,mode); } /// <summary> /// 分頁 /// </summary> /// <param name="helper"></param> /// <param name="id">分頁id</param> /// <param name="currentPageIndex">當前頁</param> /// <param name="pageSize">分頁尺寸</param> /// <param name="recordCount">記錄總數(shù)</param> /// <param name="className">分頁樣式</param> /// <param name="mode">分頁模式</param> /// <returns></returns> public static string Pager(this HtmlHelper helper, string id, int currentPageIndex, int pageSize, int recordCount,string className, PageMode mode) { return Pager(helper, id, currentPageIndex, pageSize, recordCount, null,className,mode); } /// <summary> /// 獲取普通分頁 /// </summary> /// <param name="currentPageIndex"></param> /// <param name="pageSize"></param> /// <param name="recordCount"></param> /// <returns></returns> private static string GetNormalPage(int currentPageIndex, int pageSize, int recordCount,PageMode mode) { int pageCount = (recordCount%pageSize ==0?recordCount/pageSize:recordCount/pageSize+1); StringBuilder url = new StringBuilder(); url.Append(HttpContext.Current.Request.Url.AbsolutePath+"?page={0}"); NameValueCollection collection = HttpContext.Current.Request.QueryString; string[] keys = collection.AllKeys; for (int i = 0; i < keys.Length; i++) { if (keys[i].ToLower() != "page") url.AppendFormat("&{0}={1}", keys[i], collection[keys[i]]); } StringBuilder sb = new StringBuilder(); sb.Append("<tr><td>"); sb.AppendFormat("總共{0}條記錄,共{1}頁,當前第{2}頁 ", recordCount, pageCount, currentPageIndex); if (currentPageIndex == 1) sb.Append("<span>首頁</span> "); else { string url1 = string.Format(url.ToString(), 1); sb.AppendFormat("<span><a href={0}>首頁</a></span> ", url1); } if (currentPageIndex > 1) { string url1 = string.Format(url.ToString(), currentPageIndex - 1); sb.AppendFormat("<span><a href={0}>上一頁</a></span> ", url1); } else sb.Append("<span>上一頁</span> "); if(mode == PageMode.Numeric) sb.Append(GetNumericPage(currentPageIndex,pageSize,recordCount,pageCount,url.ToString())); if (currentPageIndex < pageCount) { string url1 = string.Format(url.ToString(), currentPageIndex+1); sb.AppendFormat("<span><a href={0}>下一頁</a></span> ", url1); } else sb.Append("<span>下一頁</span> "); if (currentPageIndex == pageCount) sb.Append("<span>末頁</span> "); else { string url1 = string.Format(url.ToString(), pageCount); sb.AppendFormat("<span><a href={0}>末頁</a></span> ", url1); } return sb.ToString(); } /// <summary> /// 獲取數(shù)字分頁 /// </summary> /// <param name="currentPageIndex"></param> /// <param name="pageSize"></param> /// <param name="recordCount"></param> /// <param name="pageCount"></param> /// <param name="url"></param> /// <returns></returns> private static string GetNumericPage(int currentPageIndex, int pageSize, int recordCount, int pageCount,string url) { int k = currentPageIndex / 10; int m = currentPageIndex % 10; StringBuilder sb = new StringBuilder(); if (currentPageIndex / 10 == pageCount / 10) { if (m == 0) { k--; m = 10; } else m = pageCount%10; } else m = 10; for (int i = k * 10 + 1; i <= k * 10 + m; i++) { if (i == currentPageIndex) sb.AppendFormat("<span><font color=red><b>{0}</b></font></span> ", i); else { string url1 = string.Format(url.ToString(), i); sb.AppendFormat("<span><a href={0}>{1}</a></span> ",url1, i); } } return sb.ToString(); } } /// <summary> /// 分頁模式 /// </summary> public enum PageMode { /// <summary> /// 普通分頁模式 /// </summary> Normal, /// <summary> /// 普通分頁加數(shù)字分頁 /// </summary> Numeric } }
PagerQuery.cs包含兩個屬性,一個是PageInfo實體類屬性Pager,包含RecordCount,CurrentPageIndex,PageSize三個屬性。一個是Model EntityList屬性。
using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace System.Web.Mvc { public class PagerQuery<TPager,TEntityList> { public PagerQuery(TPager pager, TEntityList entityList) { this.Pager = pager; this.EntityList = entityList; } public TPager Pager { get; set; } public TEntityList EntityList { get; set; } } }
PageInfo.cs
using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace System.Web.Mvc { public class PagerInfo { public int RecordCount { get; set; } public int CurrentPageIndex { get; set; } public int PageSize { get; set; } } }
使用示例:
@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" Inherits="System.Web.Mvc.ViewPage<PagerQuery<PagerInfo, IList<NewsArticleInfo>>>" %> <asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server"> NewsList </asp:Content> <asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server"> <h2>NewsList</h2> <table> <tr> <th></th> <th> NoteID </th> <th> Title </th> <th> Author </th> <th> Hit </th> <th> ReplyNum </th> </tr> <% foreach (var item in Model.EntityList) { %> <tr> <td> <%= Html.ActionLink("Edit", "Edit", new { /* id=item.PrimaryKey */ }) %> | <%= Html.ActionLink("Details", "NewsDetail", new { noteID=item.NoteID })%> </td> <td> <%= Html.Encode(item.NoteID) %> </td> <td> <%= Html.Encode(item.Title) %> </td> <td> <%= Html.Encode(item.Author)%> </td> <td> <%= Html.Encode(item.Hit)%> </td> <td> <%= Html.Encode(item.ReplyNum)%> </td> </tr> <% } %> </table> <p> <%=Html.Pager("pager",Model.Pager.CurrentPageIndex,Model.Pager.PageSize,Model.Pager.RecordCount,PageMode.Numeric) %> </p> </asp:Content>
controler:
[AcceptVerbs(HttpVerbs.Get)] public ActionResult NewsList(int boardID,int? page) { PagerInfo pager = new PagerInfo(); NewsArticleInfo info = new NewsArticleInfo(); info.NewsBoard = new NewsBoardInfo(); info.NewsBoard.BoardID = boardID; pager.RecordCount = Resolve<INewsBLL>().GetArticleDataList(info, ArticleTypeEnum.Pass); pager.PageSize = 10; pager.CurrentPageIndex = (page!=null?(int)page:1); IList<NewsArticleInfo> result = Resolve<INewsBLL>().GetArticleDataList(pager.CurrentPageIndex, pager.PageSize, ArticleTypeEnum.Pass, info); PagerQuery<PagerInfo, IList<NewsArticleInfo>> query = new PagerQuery<PagerInfo, IList<NewsArticleInfo>>(pager,result); return View(query); }
源碼下載:http://xiazai.jb51.net/201609/yuanma/MvcPager(jb51.net).rar
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 學習制作MVC4分頁控件(下)
- 學習制作MVC4分頁控件(上)
- MVC默認路由實現(xiàn)分頁(PagerExtend.dll下載)
- MVC分頁之MvcPager使用詳解
- ASP.NET MVC分頁和排序功能實現(xiàn)
- ASP.NET MVC+EF在服務端分頁使用jqGrid以及jquery Datatables的注意事項
- MVC+jQuery.Ajax異步實現(xiàn)增刪改查和分頁
- 適用于WebForm Mvc的Pager分頁組件C#實現(xiàn)
- ASP.NET MVC 2右鍵菜單和簡單分頁實例講解
- ASP.NET MVC 5使用X.PagedList.Mvc進行分頁教程(PagedList.Mvc)
相關文章
.NET客戶端實現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)
本文主要介紹了.NET客戶端實現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)的相關知識。具有很好的參考價值,下面跟著小編一起來看下吧2017-03-03Windows虛擬主機與VPS如何實現(xiàn)301重定向(asp.net)
301重定向應該是研究SEO必須掌握的技術。如果你是剛接觸SEO的菜鳥,想了解什么是301重定向,請看《html實現(xiàn)301重定向的方法》一文,我在該篇隨筆中引用了Google網(wǎng)站站長工具對301重定向的解釋2011-12-12asp.net實現(xiàn)在XmlTextWriter中寫入一個CDATA的方法
這篇文章主要介紹了asp.net實現(xiàn)在XmlTextWriter中寫入一個CDATA的方法,結合實例形式分析了XmlTextWriter寫入CDATA的步驟與相關實現(xiàn)技巧,需要的朋友可以參考下2016-04-04.Net筆記:System.IO之windows文件操作的深入分析
本篇文章是對.Net中windows文件操作的使用進行了詳細的分析介紹,需要的朋友參考下2013-05-05Asp.Net 網(wǎng)站優(yōu)化系列之數(shù)據(jù)庫優(yōu)化措施 使用主從庫(全)
網(wǎng)站規(guī)模到了一定程度之后,該分的也分了,該優(yōu)化的也做了優(yōu)化,但是還是不能滿足業(yè)務上對性能的要求;這時候我們可以考慮使用主從庫。2010-06-06詳解.NET中string與StringBuilder在字符串拼接功能上的比較
string與StringBuilder的在字符串拼接時執(zhí)行效率上有差異,這篇文章主要介紹了詳解.NET中string與StringBuilder在字符串拼接功能上的比較,感興趣的小伙伴們可以參考一下2018-11-11