asp.net MVC通用分頁組件 使用方便 通用性強

来源:https://www.cnblogs.com/chengchenxu/archive/2018/03/10/8538834.html
-Advertisement-
Play Games

該分頁控制項的顯示邏輯: 1 當前頁面反色突出顯示,鏈接不可點擊 2 第一頁時首頁鏈接不可點擊 3 最後一頁時尾頁鏈接不可點擊 4 當前頁面左右各顯示頁碼可以設置調節,如果左右一樣則居中 5 當左邊頁碼不足時,右側補充 6 當右側頁面不足時左側補充 7 總顯示頁碼數為左側+右側+1(當前) 組成部分: ...


該分頁控制項的顯示邏輯:

 

1 當前頁面反色突出顯示,鏈接不可點擊

2 第一頁時首頁鏈接不可點擊

Screen Shot 2018-03-10 at 12.30.53 PM.png

3 最後一頁時尾頁鏈接不可點擊

Screen Shot 2018-03-10 at 12.31.32 PM.png

4 當前頁面左右各顯示頁碼可以設置調節,如果左右一樣則居中

Screen Shot 2018-03-10 at 12.32.02 PM.png

5 當左邊頁碼不足時,右側補充

Screen Shot 2018-03-10 at 12.32.29 PM.png

6 當右側頁面不足時左側補充

Screen Shot 2018-03-10 at 12.33.21 PM.png

7 總顯示頁碼數為左側+右側+1(當前)

 

組成部分:

 

1 PageModel 便於向組件傳遞參數

public class PageModel
    {
        /// <summary>
        /// 數據總條數
        /// </summary>
        public int DataCount { get; set; }
        /// <summary>
        /// 當前頁碼
        /// </summary>
        public int Page { get; set; }
        /// <summary>
        /// 每頁條數
        /// </summary>
        public int PageSize { get; set; }
        /// <summary>
        /// 當前頁碼左邊顯示頁數
        /// </summary>
        public int NumsOfLeft { get; set; }
        /// <summary>
        /// 當前頁碼右邊顯示頁數
        /// </summary>
        public int NumsOfRight { get; set; }
        /// <summary>
        /// 每頁允許顯示的最大條數
        /// 如果PageSize大於MaxPage則以MaxPage為準
        /// </summary>
        public int MaxPage { get; set; }
        /// <summary>
        /// 頁面前面的URL
        /// 比如URL為http://www.chengchenxu.com/1 
        /// 1為頁碼,則該屬性應該設置為:
        /// http://www.chengchenxu/
        /// </summary>
        public string Url { get; set; }
 
        public PageModel()
        {
            //設置的預設值
            this.PageSize = 10;
            this.NumsOfLeft = 4;
            this.NumsOfRight = 4;
            this.MaxPage = 30;
        }

 

 

2 分部視圖: 這是一個強類型View,最上面的要對應到你的項目的命名空間中.

@model ChengChenXu.com.PageModel.Models.PageModel
 
<ul class="pagination">
    @{
        //頁碼邏輯運算
        double d = (double)Model.DataCount / Model.PageSize;
        int pageNum = (int)Math.Ceiling(d);
        Model.Page = Model.Page < 1 ? 1 : Model.Page;
        Model.Page = Model.Page > pageNum ? pageNum : Model.Page;
        Model.PageSize = Model.PageSize > Model.MaxPage ? Model.MaxPage : Model.PageSize;
        int startNum, endNum;
        if (Model.Page > Model.NumsOfLeft)
        {
            endNum = Model.Page + Model.NumsOfRight;
        }
        else
        {
            endNum = Model.Page + Model.NumsOfRight + (Model.NumsOfLeft - Model.Page + 1);
        }
        if (pageNum - Model.Page >= Model.NumsOfRight)
        {
            startNum = Model.Page - Model.NumsOfLeft;
        }
        else
        {
            startNum = Model.Page - Model.NumsOfLeft - (Model.NumsOfRight - (pageNum - Model.Page));
        }
        startNum = startNum < 1 ? 1 : startNum;
        endNum = endNum > pageNum ? pageNum : endNum;
        //END 頁碼邏輯運算
 
        //開始顯示頁碼
         
        //顯示首頁
        if (pageNum == 1 || Model.Page == 1)
        {
            <li class="disabled"><a href="#" onclick="return false;">&laquo;</a></li>
        }
        else
        {
            <li><a href="@Model.Url">&laquo;</a></li>
        }
        //END 顯示首頁
 
        //顯示頁碼
        for (int i = startNum; i <= endNum; i++)
        {
            if (i == Model.Page)
            {
                <li class="active"><a href="#" onclick="return false;">@i</a></li>
            }
            else
            {
                <li><a href="@Model.Url@i">@i</a></li>
            }
 
        }
        //END 顯示頁碼
 
        //顯示尾頁
        if (pageNum == 1 || Model.Page == pageNum)
        {
            <li class="disabled"><a href="#" onclick="return false;">&raquo;</a></li>
        }
        else
        {
            <li><a href="@Model.Url@pageNum">&raquo;</a></li>
        }
        //END 顯示尾頁
    }
</ul>

 

使用方法:

1 在需要使用的地方添加以下代碼:

第一個參數為分部View的文件名,(要放到Shared文件夾中)

第二個參數為頁面使用ViewBag傳進來的PageModel對象 註意命名空間和ViewBag的動態標簽

@Html.Partial("PagePartial", ViewBag.PageModel as ChengChenXu.com.PageModel.Models.PageModel)

 

2 在Controller中創建PageModel對象並使用ViewBag傳遞

    public ActionResult Index(int id=1,int pagesize=10)
        {
            //模擬200條數據
            List<string> list = new List<string>();
            for (int i = 1; i <= 200; i++)
            {
                list.Add(""+i+"條數據");
            }
 
            ViewBag.List = list;
 
 
            //創建PageModel對象
            Models.PageModel pm = new Models.PageModel();
            pm.DataCount = list.Count;//數據總條數
            pm.Page = id;//當前頁碼
            pm.PageSize = pagesize;//每頁數量
            pm.Url = "/home/index/"; //URL
 
            ViewBag.PageModel = pm; //傳遞PageModel
 
 
            return View();
        }

 

 

生成代碼

樣式表請自己設計 DEMO中直接使用Bootstrap框架分頁樣式.

      <ul class="pagination">
            <li class="disabled"><a href="#" onclick="return false;">&laquo;</a></li>
                <li class="active"><a href="#" onclick="return false;">1</a></li>
                <li><a href="/home/index/2">2</a></li>
                <li><a href="/home/index/3">3</a></li>
                <li><a href="/home/index/4">4</a></li>
                <li><a href="/home/index/5">5</a></li>
                <li><a href="/home/index/6">6</a></li>
                <li><a href="/home/index/7">7</a></li>
                <li><a href="/home/index/8">8</a></li>
                <li><a href="/home/index/9">9</a></li>
            <li><a href="/home/index/20">&raquo;</a></li>
          </ul>

 

源碼和DEMO下載:

ChengChenXu.com.PageModel.rar

 

本文為博主原創,轉載請保留出處:
http://chengchenxu.com/Article/22/mvc-fenye


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • len() #測量字典中鍵值對的個數 keys() #返回一個包含字典所有key的列表 values() #返回一個包含字典所有value的列表 items() #以列表返回可便利的元組數組 補充: ...
  • (1)for迴圈里的else (2)列表append的註意點 ...
  • import java.text.SimpleDateFormat;import java.util.Calendar;import java.util.Scanner; /** * 黑色星期五,13號且為星期五 * @author JMZHANG * */public class Second20 ...
  • DirectSound以DMO(DirectX Nedua Objects)的方式提供了對原始音頻數據的處理,開發者能夠通過VC6.0里的 來開發自定義的DMO。實際上這個DMO開發嚮導已經不在Visual Studio裡面提供了,並且已經被MFT(Media Foundation Transfor ...
  • 1111111111111111 ...
  • 使用場景:網站配置項目,為了便於管理,網站有幾個Model類來管理配置文件, 比如ConfigWebsiteModel 用來管理基本信息 ConfigSeoModel 用來管理SEO信息 ConfigCacheModel 用來管理網站緩存信息 不用Model之間不能有重名屬性欄位 現在需要把他們儲存 ...
  • 下麵還有幾句心得大家可以看一下:第一點:【盲目下註】全拼運氣,一把輸了下把倍投,如果連續5把不開,基本腦袋就一片空白了關於PK10下註技巧以及心態沒了清醒的頭腦,你看任何計劃,就算連中20期的計劃你都會慫了,這個時候你就是送財童子了。第二點:【不懂分配金額】沒耐心,心急,一兩把不中,一股腦全壓了,這 ...
  • 前面Insus.NET有在Angularjs實現DropDownList的下拉列表的功能。但是沒有實現怎樣獲取下拉列表的value和text功能。 下麵分別使用ng-click和ng-change來實現。先參考這篇《ASP.NET MVC下使用AngularJs語言(三):ng-options》ht ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...