一個支持普通分頁和綜合分頁的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">當(dāng)前頁</param>
/// <param name="pageSize">分頁尺寸</param>
/// <param name="recordCount">記錄總數(shù)</param>
/// <param name="htmlAttributes">分頁頭標(biāo)簽屬性</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">當(dāng)前頁</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">當(dāng)前頁</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">當(dāng)前頁</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">當(dāng)前頁</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}頁,當(dāng)前第{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實(shí)體類屬性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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 學(xué)習(xí)制作MVC4分頁控件(下)
- 學(xué)習(xí)制作MVC4分頁控件(上)
- MVC默認(rèn)路由實(shí)現(xiàn)分頁(PagerExtend.dll下載)
- MVC分頁之MvcPager使用詳解
- ASP.NET MVC分頁和排序功能實(shí)現(xiàn)
- ASP.NET MVC+EF在服務(wù)端分頁使用jqGrid以及jquery Datatables的注意事項(xiàng)
- MVC+jQuery.Ajax異步實(shí)現(xiàn)增刪改查和分頁
- 適用于WebForm Mvc的Pager分頁組件C#實(shí)現(xiàn)
- ASP.NET MVC 2右鍵菜單和簡單分頁實(shí)例講解
- ASP.NET MVC 5使用X.PagedList.Mvc進(jìn)行分頁教程(PagedList.Mvc)
相關(guān)文章
.NET6+Quartz實(shí)現(xiàn)定時任務(wù)的示例詳解
在實(shí)際工作中,經(jīng)常會有一些需要定時操作的業(yè)務(wù),如:定時發(fā)郵件,定時統(tǒng)計(jì)信息等,那么如何實(shí)現(xiàn)才能使得我們的項(xiàng)目整齊劃一呢?本文通過一些簡單的小例子,簡述在.Net6+Quartz實(shí)現(xiàn)定時任務(wù)的一些基本操作,如有不足之處,還請指正2023-03-03
.NET客戶端實(shí)現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)
本文主要介紹了.NET客戶端實(shí)現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)的相關(guān)知識。具有很好的參考價值,下面跟著小編一起來看下吧2017-03-03
Windows虛擬主機(jī)與VPS如何實(shí)現(xiàn)301重定向(asp.net)
301重定向應(yīng)該是研究SEO必須掌握的技術(shù)。如果你是剛接觸SEO的菜鳥,想了解什么是301重定向,請看《html實(shí)現(xiàn)301重定向的方法》一文,我在該篇隨筆中引用了Google網(wǎng)站站長工具對301重定向的解釋2011-12-12
asp.net實(shí)現(xiàn)在XmlTextWriter中寫入一個CDATA的方法
這篇文章主要介紹了asp.net實(shí)現(xiàn)在XmlTextWriter中寫入一個CDATA的方法,結(jié)合實(shí)例形式分析了XmlTextWriter寫入CDATA的步驟與相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-04-04
.Net筆記:System.IO之windows文件操作的深入分析
本篇文章是對.Net中windows文件操作的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
Asp.Net 網(wǎng)站優(yōu)化系列之?dāng)?shù)據(jù)庫優(yōu)化措施 使用主從庫(全)
網(wǎng)站規(guī)模到了一定程度之后,該分的也分了,該優(yōu)化的也做了優(yōu)化,但是還是不能滿足業(yè)務(wù)上對性能的要求;這時候我們可以考慮使用主從庫。2010-06-06
詳解.NET中string與StringBuilder在字符串拼接功能上的比較
string與StringBuilder的在字符串拼接時執(zhí)行效率上有差異,這篇文章主要介紹了詳解.NET中string與StringBuilder在字符串拼接功能上的比較,感興趣的小伙伴們可以參考一下2018-11-11

