亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > NET Core TagHelper實現分頁標簽

NET Core TagHelper實現分頁標簽

熱門標簽:廣西房產智能外呼系統推薦 漯河外呼調研線路 400電話唐山辦理 旅游地圖標注線路 電銷專用外呼線路 地圖標注位置怎么弄圖 威力最大的電銷機器人 電話機器人鑰匙扣 電銷外呼系統是違法的嗎

這里將要和大家分享的是學習總結使用TagHelper實現分頁標簽,之前分享過一篇使用HtmlHelper擴展了一個分頁寫法地址可以點擊這里https://www.jb51.net/article/89272.htm,今天分享的是net core的另外一種能寫分頁標簽的方法具體是繼承TagHelper,如下將講述實現一個簡單分頁和總要注意步奏。

1.繼承父類TagHelper并重寫Process方法(這里還有一個異步的方法ProcessAsync各位可以自己嘗試下)

2.注意:怎么在試圖頁面使用自定義標簽

3.注意:怎么識別標簽中的屬性

4.注意:自定義標簽類怎么獲取分頁參數

5.效果展示

下面一步一個腳印的來分享:

1.繼承父類TagHelper并重寫Process方法(這里還有一個異步的方法ProcessAsync各位可以自己嘗試下)

首先咋們定義一個類取名為PagerTagHelper,這里需要繼承TagHelper類,重寫Process方法,TagHelper位于命名空間Microsoft.AspNetCore.Razor.TagHelpers下面,因為這里要實現的效果是mvc分頁,所以還需要通過nuget獲取引用Microsoft.AspNetCore.Mvc.TagHelpers,引用后如圖:

這里的版本是1.0.0-rc2-final,之前直接通過nuget引用默認版本是1.0.0版本如圖本地已經下載了兩個版本:

各位需要注意版本一直,不然還原程序包的時候會出錯

2.注意:怎么在試圖頁面使用自定義標簽

如果要在html中使用定義的標簽,需要注意命名規則如圖上面定義的類:

標簽類必須以TagHelper結尾,然后在試圖中使用如圖所示:

這里的pager就是上面PagerTagHelper對應的標簽,去掉固定的TagHelper然后剩余Pager,因為html標簽都是小寫所以是pager,咋們先在Process中打個斷點然后F5調試,可以看到進入了咋們重寫的方法中,這樣pager標簽就和標簽類對應上了

3.注意:怎么識別標簽中的屬性

咋們在自定義標簽類中定義個屬性(這里因為要做分頁所以這里直接定義個分頁參數的對應屬性類當做標簽類的屬性),分頁參數類如下:

/// summary>
 /// 分頁option屬性
 /// /summary>
 public class MoPagerOption
 {
  /// summary>
  /// 當前頁 必傳
  /// /summary>
  public int CurrentPage { get; set; }
  /// summary>
  /// 總條數 必傳
  /// /summary>
  public int Total { get; set; }

  /// summary>
  /// 分頁記錄數(每頁條數 默認每頁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; }
 }

然后定義的屬性PagerOption截圖如:

這里要讓定義的屬性在標簽中能使用需要注意在html中小寫,然后首個單詞后面以'-'和后面的單詞隔開,下面是試圖標簽中使用定義的屬性:

注意:

*單詞大小寫

*首個單詞后'-'分割(屬性名稱是PagerOption對應pager-option這個細節不容忽視)

4.注意:自定義標簽類怎么獲取分頁參數

這里用到上面第3點的屬性節點來傳遞參數,先看一下咋們在Controller定義的列表數據和分頁數據封裝如下:

// GET: Articles
  public async TaskIActionResult> Index(int id = 1)
  {

   var artiles = _context.Article;
   var pageOption = new MoPagerOption
   {
    CurrentPage = id,
    PageSize = 2,
    Total = await artiles.CountAsync(),
    RouteUrl = "/Articles/Index"
   };

   //分頁參數
   ViewBag.PagerOption = pageOption;

   //數據
   return View(await artiles.OrderByDescending(b => b.CreateTime).Skip((pageOption.CurrentPage - 1) * pageOption.PageSize).Take(pageOption.PageSize).ToListAsync());
  }

然后在試圖對應的自定義分頁標簽屬性中:

復制代碼 代碼如下:
1 pager pager-option="ViewBag.PagerOption as MoPagerOption">/pager>

就是這么簡單,通過標簽屬性直接傳遞到標簽類中的屬性上,需要更詳細跟中的朋友可以F5調試下看看結果,以上就是這次分享的注意點,需要注意這幾個output.TagName = "div"這個是定義一個包含了重新元素的父級元素,output.TagMode是標簽在html中表現形式,再來就是自定義標簽類的全部代碼:

using Microsoft.AspNetCore.Razor.TagHelpers;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Text.Core.Extend
{

 #region 分頁擴展 PageExtend

 /// summary>
 /// 分頁option屬性
 /// /summary>
 public class MoPagerOption
 {
  /// summary>
  /// 當前頁 必傳
  /// /summary>
  public int CurrentPage { get; set; }
  /// summary>
  /// 總條數 必傳
  /// /summary>
  public int Total { get; set; }

  /// summary>
  /// 分頁記錄數(每頁條數 默認每頁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>
 public class PagerTagHelper : TagHelper
 {

  public MoPagerOption PagerOption { get; set; }

  
  public override void Process(TagHelperContext context, TagHelperOutput output)
  {

   output.TagName = "div";

   if (PagerOption.PageSize = 0) { PagerOption.PageSize = 15; }
   if (PagerOption.CurrentPage = 0) { PagerOption.CurrentPage = 1; }
   if (PagerOption.Total = 0) { return; }

   //總頁數
   var totalPage = PagerOption.Total / PagerOption.PageSize + (PagerOption.Total % PagerOption.PageSize > 0 ? 1 : 0);
   if (totalPage = 0) { return; }
   //當前路由地址
   if (string.IsNullOrEmpty(PagerOption.RouteUrl))
   {

    //PagerOption.RouteUrl = helper.ViewContext.HttpContext.Request.RawUrl;
    if (!string.IsNullOrEmpty(PagerOption.RouteUrl))
    {

     var lastIndex = PagerOption.RouteUrl.LastIndexOf("/");
     PagerOption.RouteUrl = PagerOption.RouteUrl.Substring(0, lastIndex);
    }
   }
   PagerOption.RouteUrl = PagerOption.RouteUrl.TrimEnd('/');

   //構造分頁樣式
   var sbPage = new StringBuilder(string.Empty);
   switch (PagerOption.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>",
            PagerOption.RouteUrl,
            PagerOption.CurrentPage - 1 = 0 ? 1 : PagerOption.CurrentPage - 1);

      for (int i = 1; i = totalPage; i++)
      {

       sbPage.AppendFormat("  li {1}>a href=\"{2}/{0}\">{0}/a>/li>",
        i,
        i == PagerOption.CurrentPage ? "class=\"active\"" : "",
        PagerOption.RouteUrl);

      }

      sbPage.Append("  li>");
      sbPage.AppendFormat("   a href=\"{0}/{1}\" aria-label=\"Next\">",
           PagerOption.RouteUrl,
           PagerOption.CurrentPage + 1 > totalPage ? PagerOption.CurrentPage : PagerOption.CurrentPage + 1);
      sbPage.Append("    span aria-hidden=\"true\">raquo;/span>");
      sbPage.Append("   /a>");
      sbPage.Append("  /li>");
      sbPage.Append(" /ul>");
      sbPage.Append("/nav>");
      #endregion
     }
     break;
   }

   output.Content.SetHtmlContent(sbPage.ToString());
   //output.TagMode = TagMode.SelfClosing;
   //return base.ProcessAsync(context, output);
  }

 }
 #endregion
}

5.效果展示

分頁效果:

右鍵查看瀏覽器中的html元素:

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Visual Studio 2017下ASP.NET CORE的TagHelper智能提示解決辦法
  • 解讀ASP.NET 5 & MVC6系列教程(13):TagHelper
  • Asp.net后臺把腳本樣式輸出到head標簽中節省代碼冗余
  • asp.net正則表達式刪除指定的HTML標簽的代碼
  • asp.net 過濾圖片標簽的正則
  • asp.net core新特性之TagHelper標簽助手

標簽:銅陵 湖北 無錫 湘西 欽州 綏化 試駕邀約 焦作

巨人網絡通訊聲明:本文標題《NET Core TagHelper實現分頁標簽》,本文關鍵詞  NET,Core,TagHelper,實現,分頁,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《NET Core TagHelper實現分頁標簽》相關的同類信息!
  • 本頁收集關于NET Core TagHelper實現分頁標簽的相關信息資訊供網民參考!
  • 推薦文章
    国产一区免费观看| 国产91丝袜高跟系列| 香蕉视频亚洲一级| 国产亚洲免费观看| 日日爽天天| 一级毛片视频免费| 国产91精品系列在线观看| 久久国产精品自由自在| 国产一区二区精品| 999久久狠狠免费精品| 一 级 黄 中国色 片| 日本特黄特黄aaaaa大片| 日韩免费片| 日本免费乱人伦在线观看| 亚欧成人乱码一区二区| 日本免费区| 韩国毛片基地| 日韩免费在线| 免费的黄色小视频| 91麻豆精品国产自产在线| 一级毛片视频免费| 日韩免费片| 午夜欧美成人久久久久久| 精品国产香蕉在线播出| 欧美另类videosbestsex高清| 亚洲精品影院一区二区| 美女免费精品高清毛片在线视| 日本在线播放一区| 日韩在线观看免费| 精品久久久久久中文字幕一区| 国产一区二区精品| 91麻豆精品国产自产在线观看一区 | 欧美激情一区二区三区在线| 黄视频网站免费观看| 国产精品免费久久| 久久精品成人一区二区三区| 日本伦理片网站| 国产网站在线| 国产伦精品一区二区三区无广告| 国产国产人免费视频成69堂| 中文字幕一区二区三区精彩视频| 精品国产一区二区三区精东影业| 精品国产三级a| a级毛片免费全部播放| 精品视频在线观看免费| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产一区二区精品尤物| 香蕉视频亚洲一级| 黄视频网站免费看| 欧美激情一区二区三区在线| 国产一区二区福利久久| 久久国产一区二区| 91麻豆精品国产自产在线 | 国产成人精品影视| 韩国毛片| 亚洲www美色| 久久99这里只有精品国产| 免费一级片网站| 九九九网站| 国产成人精品综合| 国产伦精品一区二区三区无广告 | 国产伦精品一区二区三区无广告 | 国产成人女人在线视频观看| 欧美a级v片不卡在线观看| 日本特黄特色aaa大片免费| 国产不卡在线看| 免费国产在线观看| 成人av在线播放| 国产不卡在线看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 免费毛片基地| 天天做人人爱夜夜爽2020毛片| 成人免费观看的视频黄页| 国产一区二区精品| 高清一级毛片一本到免费观看| 国产成人精品一区二区视频| 一级女人毛片人一女人| 国产一区免费在线观看| 91麻豆精品国产片在线观看| 成人免费福利片在线观看| 国产麻豆精品hdvideoss| 国产视频网站在线观看| 日本在线播放一区| 九九久久国产精品大片| 成人在激情在线视频| 国产一区二区福利久久| 精品视频免费看| 黄色福利片| 中文字幕一区二区三区 精品| 国产一区二区精品| 日本在线www| 久久国产影视免费精品| 91麻豆tv| 日韩av成人| 国产91精品一区| 一级毛片视频免费| 97视频免费在线观看| 国产不卡在线观看| 久久成人性色生活片| 欧美国产日韩精品| 精品国产一区二区三区国产馆| 99色播| 亚洲精品影院| 九九免费精品视频| 国产视频一区二区三区四区| 黄色免费三级| 中文字幕一区二区三区精彩视频| 99久久精品国产免费| 午夜精品国产自在现线拍| 国产网站免费在线观看| 韩国三级视频网站| 日韩一级黄色| 欧美国产日韩精品| 你懂的国产精品| 一本伊大人香蕉高清在线观看| 91麻豆国产福利精品| 精品视频在线观看一区二区| 亚洲精品久久玖玖玖玖| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美a级片免费看| 国产一区二区精品尤物| 国产高清视频免费观看| 欧美国产日韩精品| 天天做人人爱夜夜爽2020毛片| 日韩字幕在线| 美女被草网站| 日本特黄一级| 欧美一级视频免费观看| 日韩免费在线视频| 欧美大片a一级毛片视频| 国产成a人片在线观看视频| 精品视频在线观看一区二区| 国产伦精品一区三区视频| 美女被草网站| 成人在免费观看视频国产| 国产高清在线精品一区a| 欧美激情一区二区三区在线播放 | 欧美激情一区二区三区在线| 欧美国产日韩在线| 国产韩国精品一区二区三区| 国产视频一区在线| 国产美女在线观看| 成人av在线播放| 国产成人精品综合| 四虎影视久久久免费| 精品视频免费看| 国产不卡高清| 欧美电影免费看大全| 久久久久久久免费视频| 国产网站免费在线观看| 青青青草视频在线观看| 91麻豆国产福利精品| 九九免费精品视频| 久久精品欧美一区二区| 999精品在线| 国产激情一区二区三区| 欧美国产日韩久久久| 久久精品店| 久久国产精品只做精品| 韩国毛片| 亚洲女初尝黑人巨高清在线观看| 欧美大片一区| 欧美国产日韩精品| 你懂的国产精品| 一级片免费在线观看视频| 国产成a人片在线观看视频| 国产一区二区精品在线观看| 韩国三级香港三级日本三级| 国产91精品系列在线观看| 国产亚洲精品成人a在线| 精品久久久久久综合网| 91麻豆精品国产自产在线 | 日韩一级黄色片| 999精品在线| 国产原创中文字幕| 精品久久久久久免费影院| 国产a视频| 可以免费看毛片的网站| 天天做日日爱夜夜爽| 国产一区二区精品久久| 九九久久99| 国产麻豆精品高清在线播放| 99色视频在线观看| 成人免费网站视频ww| 免费一级片在线| 久久成人性色生活片| 国产麻豆精品hdvideoss| 国产综合91天堂亚洲国产| 欧美大片a一级毛片视频| 免费一级生活片| 国产成人精品综合久久久| 成人免费福利片在线观看| 精品国产一区二区三区免费| 尤物视频网站在线观看| 精品视频免费在线| 国产91精品露脸国语对白| 天天做日日爱夜夜爽| 国产一区二区精品| 亚洲精品久久玖玖玖玖| 欧美激情一区二区三区视频|