MVC默認(rèn)路由實(shí)現(xiàn)分頁(yè)(PagerExtend.dll下載)
這兩天在群里有人咨詢有沒有現(xiàn)成的.net mvc分頁(yè)方法,由此寫了一個(gè)簡(jiǎn)單分頁(yè)工具,這里簡(jiǎn)單分享下實(shí)現(xiàn)思路,代碼,希望能對(duì)大家有些幫助,鼓勵(lì)大家多造些輪子還是好的。
A.效果(這里用了bootstrap的樣式)

B.分析,知識(shí)點(diǎn)
a.分頁(yè)通常由一下幾個(gè)屬性組成(當(dāng)前頁(yè),總條數(shù),分頁(yè)記錄數(shù),路由地址),由此四項(xiàng)基本就能實(shí)現(xiàn)分頁(yè)了,在加上一個(gè)控制樣式的參數(shù)
b.各種數(shù)字的驗(yàn)證,計(jì)算總頁(yè)數(shù)(如果總條數(shù)和分頁(yè)記錄數(shù)不能整除,那么最后相除的結(jié)果再+1)
c.下一頁(yè)和上一下的按鈕是零界點(diǎn),需要判斷是否是最后一頁(yè)或者第一頁(yè)來(lái)顯示當(dāng)前頁(yè)數(shù)的繼續(xù)增加或者減小
d.因?yàn)樾枰赾shtml文件中展示分頁(yè)的效果,所以需要用到HtmlHelper擴(kuò)展方法;擴(kuò)展方法這里簡(jiǎn)單說(shuō)下注意項(xiàng):
.關(guān)鍵詞this
.擴(kuò)展方法對(duì)應(yīng)的clas必須靜態(tài),該方法本身也是靜態(tài)
.擴(kuò)展方法對(duì)應(yīng)的class后綴一般是Extensions修飾
e.試圖頁(yè)面@Html.PageExtend直接調(diào)用分頁(yè)方法
C.代碼展示
a.分頁(yè)方法實(shí)現(xiàn)類
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Web.Mvc;
namespace PagerExtend
{
public static class HtmlHelperExtensions
{
#region 分頁(yè)擴(kuò)展 PageExtend
/// <summary>
/// 分頁(yè)option屬性
/// </summary>
public class MoPagerOption
{
/// <summary>
/// 當(dāng)前頁(yè) 必傳
/// </summary>
public int CurrentPage { get; set; }
/// <summary>
/// 總條數(shù) 必傳
/// </summary>
public int Total { get; set; }
/// <summary>
/// 分頁(yè)記錄數(shù)(每頁(yè)條數(shù) 默認(rèn)每頁(yè)15條)
/// </summary>
public int PageSize { get; set; }
/// <summary>
/// 路由地址(格式如:/Controller/Action) 默認(rèn)自動(dòng)獲取
/// </summary>
public string RouteUrl { get; set; }
/// <summary>
/// 樣式 默認(rèn) bootstrap樣式 1
/// </summary>
public int StyleNum { get; set; }
}
/// <summary>
/// 分頁(yè)擴(kuò)展方法
/// </summary>
/// <param name="helper">html試圖</param>
/// <param name="option">分頁(yè)屬性</param>
/// <returns>html樣式</returns>
public static MvcHtmlString PageExtend(this HtmlHelper helper, MoPagerOption option)
{
if (option.PageSize <= 0) { option.PageSize = 15; }
if (option.CurrentPage <= 0) { option.CurrentPage = 1; }
if (option.Total <= 0) { return MvcHtmlString.Empty; }
//總頁(yè)數(shù)
var totalPage = option.Total / option.PageSize + (option.Total % option.PageSize > 0 ? 1 : 0);
if (totalPage <= 0) { return MvcHtmlString.Create("分頁(yè)異常"); }
//當(dāng)前路由地址
if (string.IsNullOrEmpty(option.RouteUrl))
{
option.RouteUrl = helper.ViewContext.HttpContext.Request.RawUrl;
if (!string.IsNullOrEmpty(option.RouteUrl))
{
var lastIndex = option.RouteUrl.LastIndexOf("/");
option.RouteUrl = option.RouteUrl.Substring(0, lastIndex);
}
}
option.RouteUrl = option.RouteUrl.TrimEnd('/');
//構(gòu)造分頁(yè)樣式
var sbPage = new StringBuilder(string.Empty);
switch (option.StyleNum)
{
case 2:
{
break;
}
default:
{
#region 默認(rèn)樣式
sbPage.Append("<nav>");
sbPage.Append(" <ul class=\"pagination\">");
sbPage.AppendFormat(" <li><a href=\"{0}/{1}\" aria-label=\"Previous\"><span aria-hidden=\"true\">«</span></a></li>",
option.RouteUrl,
option.CurrentPage - 1 <= 0 ? 1 : option.CurrentPage - 1);
for (int i = 1; i <= totalPage; i++)
{
sbPage.AppendFormat(" <li {1}><a href=\"{2}/{0}\">{0}</a></li>",
i,
i == option.CurrentPage ? "class=\"active\"" : "",
option.RouteUrl);
}
sbPage.Append(" <li>");
sbPage.AppendFormat(" <a href=\"{0}/{1}\" aria-label=\"Next\">",
option.RouteUrl,
option.CurrentPage + 1 > totalPage ? option.CurrentPage : option.CurrentPage + 1);
sbPage.Append(" <span aria-hidden=\"true\">»</span>");
sbPage.Append(" </a>");
sbPage.Append(" </li>");
sbPage.Append(" </ul>");
sbPage.Append("</nav>");
#endregion
}
break;
}
return MvcHtmlString.Create(sbPage.ToString());
}
#endregion
}
}
b.View測(cè)試調(diào)用
@using PagerExtend
@model IEnumerable<XinSheng.Api.Controllers.MoAirticle>
<table>
Url:@ViewBag.Url
@foreach (var item in Model)
{
<tr>
<td>@item.Title</td>
<td>@item.Author</td>
<td>@item.CreateTime</td>
</tr>
}
</table>
@Html.PageExtend(ViewBag.PagerOption as HtmlHelperExtensions.MoPagerOption)
c.Controller測(cè)試
using PagerExtend;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Security;
namespace XinSheng.Api.Controllers
{
[Serializable]
public class MoAirticle
{
public string Title { get; set; }
public string Author { get; set; }
public DateTime CreateTime { get; set; }
}
public class HomeController : Controller
{
public ActionResult Index(int id)
{
ViewBag.Title = "測(cè)試 分頁(yè)";
List<MoAirticle> moAirticles = new List<MoAirticle>();
for (int i = 1; i < 50; i++)
{
moAirticles.Add(new MoAirticle
{
Author = "神牛步行" + i,
CreateTime = DateTime.Now,
Title = "博客園之" + i
});
}
ViewBag.Url = Request.RawUrl;
//初始化分頁(yè)基礎(chǔ)信息
var option = new HtmlHelperExtensions.MoPagerOption
{
CurrentPage = id,
PageSize = 15,
Total = moAirticles.Count
};
//動(dòng)態(tài)傳遞分頁(yè)屬性
ViewBag.PagerOption = option;
var articles = moAirticles.Skip((option.CurrentPage - 1) * option.PageSize).Take(option.PageSize).ToList();
return View(articles);
}
}
}
D.分頁(yè)P(yáng)agerExtend.dll下載地址:PagerExtend.rar
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- MVC分頁(yè)之MvcPager使用詳解
- Java簡(jiǎn)單實(shí)現(xiàn)SpringMVC+MyBatis分頁(yè)插件
- ASP.NET MVC 5使用X.PagedList.Mvc進(jìn)行分頁(yè)教程(PagedList.Mvc)
- ASPNETPAGER分頁(yè)控件的使用方法[圖文]
- ASP.NET 高性能分頁(yè)代碼
- Asp.Net中的三種分頁(yè)方式總結(jié)
- Asp.net GridView使用大全(分頁(yè)實(shí)現(xiàn))
- Asp.Net數(shù)據(jù)控件引用AspNetPager.dll分頁(yè)實(shí)現(xiàn)代碼
- asp.net Datalist控件實(shí)現(xiàn)分頁(yè)功能
- asp.net分頁(yè)控件AspNetPager的樣式美化
相關(guān)文章
asp.net中JavaScript數(shù)據(jù)驗(yàn)證實(shí)現(xiàn)代碼
我對(duì)JavaScript一直不了解。常常為了一點(diǎn)點(diǎn)的數(shù)據(jù)驗(yàn)證和無(wú)刷新就去動(dòng)用AJAX,實(shí)在不爽——有點(diǎn)殺雞用牛刀的感覺。2010-05-05
ASP.NET Core應(yīng)用中與第三方IoC/DI框架的整合
ASP.NET Core應(yīng)用中,針對(duì)第三方DI框架的整合可以通過(guò)在定義Startup類型的ConfigureServices方法返回一個(gè)ServiceProvider來(lái)實(shí)現(xiàn)。但是并不是那么容易的,下面通過(guò)實(shí)例給大家分享一下2017-04-04
asp.net(vb)實(shí)現(xiàn)金額轉(zhuǎn)換成大寫的函數(shù)
asp.net(vb)實(shí)現(xiàn)金額轉(zhuǎn)換成大寫的函數(shù)代碼,需要的朋友可以參考下。2011-10-10
asp.net?web?api2設(shè)置默認(rèn)啟動(dòng)登錄頁(yè)面的方法
這篇文章主要介紹了asp.net?web?api2設(shè)置默認(rèn)啟動(dòng)登錄頁(yè)面的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-09-09
.aspx中的命名空間設(shè)置實(shí)現(xiàn)代碼
原來(lái)以為.aspx 與.cs文件是屬于同一個(gè)類,今天才意識(shí)到自己錯(cuò)了。2009-04-04

