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

B.分析,知識點
a.分頁通常由一下幾個屬性組成(當(dāng)前頁,總條數(shù),分頁記錄數(shù),路由地址),由此四項基本就能實現(xiàn)分頁了,在加上一個控制樣式的參數(shù)
b.各種數(shù)字的驗證,計算總頁數(shù)(如果總條數(shù)和分頁記錄數(shù)不能整除,那么最后相除的結(jié)果再+1)
c.下一頁和上一下的按鈕是零界點,需要判斷是否是最后一頁或者第一頁來顯示當(dāng)前頁數(shù)的繼續(xù)增加或者減小
d.因為需要在cshtml文件中展示分頁的效果,所以需要用到HtmlHelper擴展方法;擴展方法這里簡單說下注意項:
.關(guān)鍵詞this
.擴展方法對應(yīng)的clas必須靜態(tài),該方法本身也是靜態(tài)
.擴展方法對應(yīng)的class后綴一般是Extensions修飾
e.試圖頁面@Html.PageExtend直接調(diào)用分頁方法
C.代碼展示
a.分頁方法實現(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 分頁擴展 PageExtend
/// <summary>
/// 分頁option屬性
/// </summary>
public class MoPagerOption
{
/// <summary>
/// 當(dāng)前頁 必傳
/// </summary>
public int CurrentPage { get; set; }
/// <summary>
/// 總條數(shù) 必傳
/// </summary>
public int Total { get; set; }
/// <summary>
/// 分頁記錄數(shù)(每頁條數(shù) 默認每頁15條)
/// </summary>
public int PageSize { get; set; }
/// <summary>
/// 路由地址(格式如:/Controller/Action) 默認自動獲取
/// </summary>
public string RouteUrl { get; set; }
/// <summary>
/// 樣式 默認 bootstrap樣式 1
/// </summary>
public int StyleNum { get; set; }
}
/// <summary>
/// 分頁擴展方法
/// </summary>
/// <param name="helper">html試圖</param>
/// <param name="option">分頁屬性</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; }
//總頁數(shù)
var totalPage = option.Total / option.PageSize + (option.Total % option.PageSize > 0 ? 1 : 0);
if (totalPage <= 0) { return MvcHtmlString.Create("分頁異常"); }
//當(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)造分頁樣式
var sbPage = new StringBuilder(string.Empty);
switch (option.StyleNum)
{
case 2:
{
break;
}
default:
{
#region 默認樣式
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測試調(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測試
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 = "測試 分頁";
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;
//初始化分頁基礎(chǔ)信息
var option = new HtmlHelperExtensions.MoPagerOption
{
CurrentPage = id,
PageSize = 15,
Total = moAirticles.Count
};
//動態(tài)傳遞分頁屬性
ViewBag.PagerOption = option;
var articles = moAirticles.Skip((option.CurrentPage - 1) * option.PageSize).Take(option.PageSize).ToList();
return View(articles);
}
}
}
D.分頁PagerExtend.dll下載地址:PagerExtend.rar
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- MVC分頁之MvcPager使用詳解
- Java簡單實現(xiàn)SpringMVC+MyBatis分頁插件
- ASP.NET MVC 5使用X.PagedList.Mvc進行分頁教程(PagedList.Mvc)
- ASPNETPAGER分頁控件的使用方法[圖文]
- ASP.NET 高性能分頁代碼
- Asp.Net中的三種分頁方式總結(jié)
- Asp.net GridView使用大全(分頁實現(xiàn))
- Asp.Net數(shù)據(jù)控件引用AspNetPager.dll分頁實現(xiàn)代碼
- asp.net Datalist控件實現(xiàn)分頁功能
- asp.net分頁控件AspNetPager的樣式美化
相關(guān)文章
合并網(wǎng)頁中的多個script引用實現(xiàn)思路及代碼
為了更好的進行封裝,每個實現(xiàn)不同功能的js代碼應(yīng)該有自己的js文件,這樣如果一個網(wǎng)頁中引用了多個js文件會很難管理,所以就出現(xiàn)了合并js這以說,感興趣的朋友不妨參考下本文希望對你有所幫助2013-02-02
ASP.NET Core MVC解決控制器同名Action請求不明確的問題
這篇文章主要介紹了ASP.NET Core MVC解決控制器同名Action請求不明確的問題,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
asp.net中ADO SQL數(shù)據(jù)庫 筆記匯總 持續(xù)更新中
asp.net中ADO SQL數(shù)據(jù)庫 筆記匯總 持續(xù)更新中,需要的朋友可以參考下2012-07-07
創(chuàng)建一個完整的ASP.NET Web API項目
ASP.NET Web API具有與ASP.NET MVC類似的編程方式,ASP.NET Web API不僅僅具有一個完全獨立的消息處理管道,而且這個管道比為ASP.NET MVC設(shè)計的管道更為復(fù)雜,功能也更為強大。下面創(chuàng)建一個簡單的Web API項目,需要的朋友可以參考下2015-10-10
asp.net實現(xiàn)的計算網(wǎng)頁下載速度的代碼
剛看到有人給出asp.net實現(xiàn)的計算網(wǎng)頁下載速度的方法,本方法未經(jīng)本人測試,不知道能否可靠性如何。準(zhǔn)確來說,這只是個思路吧2013-03-03
ASP.NET2.0中數(shù)據(jù)源控件之異步數(shù)據(jù)訪問
ASP.NET2.0中數(shù)據(jù)源控件之異步數(shù)據(jù)訪問...2006-09-09
Asp.Net中的字符串和HTML十進制編碼轉(zhuǎn)換實現(xiàn)代碼
這篇文章主要介紹了Asp.Net中的字符串和HTML十進制編碼轉(zhuǎn)換實現(xiàn)代碼,本文一并列出了javascript語言的實現(xiàn)方法,用以實現(xiàn)字符串和HTML十進制編碼之間互相轉(zhuǎn)換功能,需要的朋友可以參考下2014-08-08

