<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        asp.net mvc自定義pager封裝與優(yōu)化

        來源:懂視網 責編:小采 時間:2020-11-27 22:36:31
        文檔

        asp.net mvc自定義pager封裝與優(yōu)化

        asp.net mvc自定義pager封裝與優(yōu)化:之前做了一個通用的分頁組件,但是有些不足,從翻頁事件和分頁樣式都融合在后臺代碼中,到翻頁事件可以自定義,再到翻頁和樣式都和代碼分離, 自定義分頁 pager 越來越容易擴展了。 HtmlHelper Pager擴展 Pager V1.0 : /// <summary&
        推薦度:
        導讀asp.net mvc自定義pager封裝與優(yōu)化:之前做了一個通用的分頁組件,但是有些不足,從翻頁事件和分頁樣式都融合在后臺代碼中,到翻頁事件可以自定義,再到翻頁和樣式都和代碼分離, 自定義分頁 pager 越來越容易擴展了。 HtmlHelper Pager擴展 Pager V1.0 : /// <summary&

        之前做了一個通用的分頁組件,但是有些不足,從翻頁事件和分頁樣式都融合在后臺代碼中,到翻頁事件可以自定義,再到翻頁和樣式都和代碼分離, 自定義分頁 pager 越來越容易擴展了。

        HtmlHelper Pager擴展

        Pager V1.0 :

        /// <summary>
         /// Pager V1.0
         /// </summary>
         /// <param name="helper">HtmlHelper</param>
         /// <param name="pager">分頁信息</param>
         /// <returns></returns>
         public static MvcHtmlString Pager(this HtmlHelper helper, PagerModel pager)
         {
         StringBuilder sbHtmlText = new StringBuilder();
         sbHtmlText.Append("<div style=\"text-align:center\"><nav><ul class=\"pagination\">");
         if (pager.PageIndex <= 1)
         {
         sbHtmlText.Append("<li class=\"disabled\"><a href=\"javascript:void(0)\" aria-label=\"Previous\"><span aria-hidden=\"true\">«</span></a></li>");
         }
         else
         {
         sbHtmlText.AppendFormat("<li><a href=\"javascript:loadData(1)\" aria-label=\"1\"><span aria-hidden=\"true\">«</span></a></li>", pager.PageIndex - 1);
         sbHtmlText.AppendFormat("<li><a href=\"javascript:loadData({0})\">{0}</a></li>", pager.PageIndex - 1);
         }
         sbHtmlText.AppendFormat("<li class=\"active\"><a href=\"javascript:void(0)\">{0}<span class=\"sr-only\">(current)</span></a></li>", pager.PageIndex);
         if (pager.PageIndex >= pager.PageCount)
         {
         sbHtmlText.Append("<li class=\"disabled\"><a href=\"javascript:void(0)\" aria-label=\"Next\"><span aria-hidden=\"true\">»</span></a></li>");
         }
         else
         {
         sbHtmlText.AppendFormat("<li><a href=\"javascript:loadData({0})\">{0}</a></li>", pager.PageIndex + 1);
         sbHtmlText.AppendFormat("<li><a href=\"javascript:loadData({0})\" aria-label=\"Next\"><span aria-hidden=\"true\">»</span></a></li>", pager.PageIndex + 1);
         }
         sbHtmlText.Append("</ul></nav>");
         sbHtmlText.AppendFormat("<div><span>每頁有<strong>{0}</strong>條數據,一共有<strong>{1}</strong>頁,總計<strong>{2}</strong>條數據</span></div></div>", pager.PageSize, pager.PageCount, pager.TotalCount);
         return MvcHtmlString.Create(sbHtmlText.ToString());
         } 
        

        Pager V2.0

        /// <summary>
         /// Pager V2.0
         /// </summary>
         /// <param name="helper">HtmlHelper</param>
         /// <param name="pager">分頁信息</param>
         /// <param name="onPageChange">翻頁事件</param>
         /// <returns></returns>
         public static MvcHtmlString Pager(this HtmlHelper helper, PagerModel pager, Func<int, string> onPageChange)
         {
         StringBuilder sbHtmlText = new StringBuilder();
         sbHtmlText.Append("<div style=\"text-align:center\"><nav><ul class=\"pagination\">");
         if (pager.PageIndex <= 1)
         {
         sbHtmlText.Append("<li class=\"disabled\"><a href=\"javascript:void(0)\" aria-label=\"Previous\"><span aria-hidden=\"true\">«</span></a></li>");
         }
         else
         {
         sbHtmlText.AppendFormat("<li><a href=\"{0}\" aria-label=\"Previous\"><span aria-hidden=\"true\">«</span></a></li>", onPageChange(pager.PageIndex - 1));
         sbHtmlText.AppendFormat("<li><a href=\"{0}\">{1}</a></li>", onPageChange(pager.PageIndex - 1), pager.PageIndex - 1);
         }
         sbHtmlText.AppendFormat("<li class=\"active\"><a href=\"javascript:void(0)\">{0}<span class=\"sr-only\">(current)</span></a></li>", pager.PageIndex);
         if (pager.PageIndex >= pager.PageCount)
         {
         sbHtmlText.Append("<li class=\"disabled\"><a href=\"javascript:void(0)\" aria-label=\"Next\"><span aria-hidden=\"true\">»</span></a></li>");
         }
         else
         {
         sbHtmlText.AppendFormat("<li><a href=\"{0}\">{1}</a></li>", onPageChange(pager.PageIndex + 1), pager.PageIndex + 1);
         sbHtmlText.AppendFormat("<li><a href=\"{0}\" aria-label=\"Next\"><span aria-hidden=\"true\">»</span></a></li>", onPageChange(pager.PageIndex + 1));
         }
         sbHtmlText.Append("</ul></nav>");
         sbHtmlText.AppendFormat("<div><span>每頁有<strong>{0}</strong>條數據,一共有<strong>{1}</strong>頁,總計<strong>{2}</strong>條數據</span></div></div>", pager.PageSize, pager.PageCount, pager.TotalCount);
         return MvcHtmlString.Create(sbHtmlText.ToString());
         } 
        

        Pager V3.0

        /// <summary>
         /// Pager V3.0
         /// </summary>
         /// <param name="helper">HtmlHelper</param>
         /// <param name="pager">分頁信息</param>
         /// <param name="onPageChange">翻頁地址或事件</param>
         /// <param name="pagerViewName">分頁分部視圖名稱</param>
         /// <param name="displayMode">分頁顯示模式</param>
         /// <returns></returns>
         public static MvcHtmlString Pager(this HtmlHelper helper, PagerModel pager, Func<int, string> onPageChange, string pagerViewName, PagingDisplayMode displayMode = PagingDisplayMode.Always)
         {
         pager.OnPageChange = onPageChange;
         pager.PagingDisplayMode = displayMode;
         return MvcHtmlString.Create(helper.Partial(pagerViewName, pager).ToHtmlString());
         }
         

        Summary

        Pager V1.0 分頁樣式和翻頁事件如果要修改都要修改 CSharp 代碼

        Pager V2.0 可以自定義翻頁事件,但是要修改分頁樣式還是要修改 CSharp 代碼

        Pager V3.0 可以在自定義分頁分部視圖中修改翻頁事件或地址和分頁樣式

        End

        現(xiàn)在已經將這個項目 MvcSimplePager 打包到 Nuget http://www.nuget.org/packages/MvcSimplePager/,你可以在VS中 nuget 包管理器中搜索 MvcSimplePager 進行使用。

        自定義 MvcSimplePager 項目和示例代碼:https://github.com/WeihanLi/MvcSimplePager ,你可以根據需要再進行自己的定制。

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        asp.net mvc自定義pager封裝與優(yōu)化

        asp.net mvc自定義pager封裝與優(yōu)化:之前做了一個通用的分頁組件,但是有些不足,從翻頁事件和分頁樣式都融合在后臺代碼中,到翻頁事件可以自定義,再到翻頁和樣式都和代碼分離, 自定義分頁 pager 越來越容易擴展了。 HtmlHelper Pager擴展 Pager V1.0 : /// <summary&
        推薦度:
        標簽: 封裝 net mvc
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产在线19禁免费观看国产| 中字幕视频在线永久在线观看免费| 国产精品免费看香蕉| 亚洲视频无码高清在线| 噼里啪啦免费观看高清动漫4 | 亚洲黄色免费观看| 亚洲AV成人无码久久精品老人| 免费人成网站在线观看不卡| 亚洲AV午夜成人片| 五月婷婷在线免费观看| 国产午夜成人免费看片无遮挡 | 国产大陆亚洲精品国产| 四虎永久免费观看| 一级做a爰全过程免费视频毛片| 中文字幕亚洲无线码| 久久久久久AV无码免费网站| 97久久精品亚洲中文字幕无码| 我们的2018在线观看免费高清| 亚洲人成电影网站色www| 免费在线视频一区| 亚洲精品国产成人| 欧洲精品成人免费视频在线观看| 最新亚洲卡一卡二卡三新区| 四虎永久成人免费| 一个人免费视频观看在线www| 亚洲黄色在线网站| 国产禁女女网站免费看| 中文字幕看片在线a免费| 亚洲美女精品视频| 国产高清在线免费| 国产成人免费ā片在线观看老同学 | 欧洲亚洲国产精华液| 狠狠亚洲狠狠欧洲2019| 1000部无遮挡拍拍拍免费视频观看| 亚洲中字慕日产2021| 亚洲中文字幕乱码熟女在线| 99热在线免费播放| 亚洲国产精品视频| 久久国产免费一区二区三区| 亚洲夂夂婷婷色拍WW47| 国产亚洲美女精品久久久2020|