溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

MVC默認路由如何實現(xiàn)分頁

發(fā)布時間:2021-08-27 09:49:48 來源:億速云 閱讀:132 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹MVC默認路由如何實現(xiàn)分頁,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

A.效果(這里用了bootstrap的樣式)

MVC默認路由如何實現(xiàn)分頁

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\">&laquo;</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\">&raquo;</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);
  }
 }
}

以上是“MVC默認路由如何實現(xiàn)分頁”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

mvc
AI