校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > NET Core TagHelper實現(xiàn)分頁標(biāo)簽

NET Core TagHelper實現(xiàn)分頁標(biāo)簽

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

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

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

2.注意:怎么在試圖頁面使用自定義標(biāo)簽

3.注意:怎么識別標(biāo)簽中的屬性

4.注意:自定義標(biāo)簽類怎么獲取分頁參數(shù)

5.效果展示

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

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

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

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

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

2.注意:怎么在試圖頁面使用自定義標(biāo)簽

如果要在html中使用定義的標(biāo)簽,需要注意命名規(guī)則如圖上面定義的類:

標(biāo)簽類必須以TagHelper結(jié)尾,然后在試圖中使用如圖所示:

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

3.注意:怎么識別標(biāo)簽中的屬性

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

/// 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ù) 默認(rèn)每頁15條)
  /// /summary>
  public int PageSize { get; set; }

  /// summary>
  /// 路由地址(格式如:/Controller/Action) 默認(rèn)自動獲取
  /// /summary>
  public string RouteUrl { get; set; }

  /// summary>
  /// 樣式 默認(rèn) bootstrap樣式 1
  /// /summary>
  public int StyleNum { get; set; }
 }

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

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

注意:

*單詞大小寫

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

4.注意:自定義標(biāo)簽類怎么獲取分頁參數(shù)

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

// 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"
   };

   //分頁參數(shù)
   ViewBag.PagerOption = pageOption;

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

然后在試圖對應(yīng)的自定義分頁標(biāo)簽屬性中:

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

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

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>
  /// 當(dāng)前頁 必傳
  /// /summary>
  public int CurrentPage { get; set; }
  /// summary>
  /// 總條數(shù) 必傳
  /// /summary>
  public int Total { get; set; }

  /// summary>
  /// 分頁記錄數(shù)(每頁條數(shù) 默認(rèn)每頁15條)
  /// /summary>
  public int PageSize { get; set; }

  /// summary>
  /// 路由地址(格式如:/Controller/Action) 默認(rèn)自動獲取
  /// /summary>
  public string RouteUrl { get; set; }

  /// summary>
  /// 樣式 默認(rèn) bootstrap樣式 1
  /// /summary>
  public int StyleNum { get; set; }
 }

 /// summary>
 /// 分頁標(biāo)簽
 /// /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; }

   //總頁數(shù)
   var totalPage = PagerOption.Total / PagerOption.PageSize + (PagerOption.Total % PagerOption.PageSize > 0 ? 1 : 0);
   if (totalPage = 0) { return; }
   //當(dāng)前路由地址
   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('/');

   //構(gòu)造分頁樣式
   var sbPage = new StringBuilder(string.Empty);
   switch (PagerOption.StyleNum)
   {
    case 2:
     {
      break;
     }
    default:
     {
      #region 默認(rèn)樣式

      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元素:

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《NET Core TagHelper實現(xiàn)分頁標(biāo)簽》,本文關(guān)鍵詞  NET,Core,TagHelper,實現(xiàn),分頁,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《NET Core TagHelper實現(xiàn)分頁標(biāo)簽》相關(guān)的同類信息!
  • 本頁收集關(guān)于NET Core TagHelper實現(xiàn)分頁標(biāo)簽的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    97久久超碰国产精品电影| 国产成人精品一区二| 一区二区三区欧美日| 1000精品久久久久久久久| 国产精品视频线看| 亚洲国产精品二十页| 中文字幕精品在线不卡| 国产精品嫩草影院av蜜臀| 中文字幕在线一区二区三区| 国产精品久久三区| 自拍偷拍亚洲激情| 亚洲一区在线观看网站| 亚洲444eee在线观看| 免费观看日韩电影| 韩国中文字幕2020精品| 国产精品一线二线三线精华| 国内精品嫩模私拍在线| 韩国精品一区二区| 国产偷v国产偷v亚洲高清 | 91亚洲国产成人精品一区二三| 国产电影精品久久禁18| 成人在线综合网| 色天天综合久久久久综合片| 在线观看国产日韩| 欧美一区二区福利视频| 欧美精品一区二区在线播放 | 午夜精品久久久久久不卡8050| 亚洲成人你懂的| 久久精品国产99久久6| 国产成人三级在线观看| 波多野结衣91| 欧美色视频一区| 亚洲精品一区二区三区蜜桃下载 | 亚洲免费观看视频| 日韩精品一二三四| 国产精品一区二区免费不卡| 99国产精品99久久久久久| 欧美色电影在线| 国产一区二区在线视频| 国产精品婷婷午夜在线观看| 日本一区二区三区免费乱视频| 丁香网亚洲国际| 99国产精品国产精品毛片| 色综合久久88色综合天天| 成人av在线资源网站| 老司机免费视频一区二区三区| 极品尤物av久久免费看| 日韩国产成人精品| 波波电影院一区二区三区| 粉嫩在线一区二区三区视频| 日韩**一区毛片| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲欧美日韩系列| 久久se精品一区精品二区| fc2成人免费人成在线观看播放 | 精品国产髙清在线看国产毛片| 日本一区二区三区四区在线视频 | 久久99精品久久久久婷婷| 99久久久久久| 精品国产乱码久久久久久牛牛| 亚洲色大成网站www久久九九| 久久国产精品72免费观看| 一本大道久久a久久综合| 久久嫩草精品久久久久| 五月天久久比比资源色| 白白色 亚洲乱淫| 精品少妇一区二区三区日产乱码| 玉足女爽爽91| 成人理论电影网| 日韩欧美三级在线| 亚洲va韩国va欧美va精品| aaa亚洲精品一二三区| www久久久久| 天堂午夜影视日韩欧美一区二区| 99麻豆久久久国产精品免费| 精品国产免费久久| 免费不卡在线观看| 国产精品超碰97尤物18| 国产人成亚洲第一网站在线播放| 亚洲三级久久久| 国产麻豆9l精品三级站| 欧美日韩免费一区二区三区视频| 2023国产一二三区日本精品2022| 1000精品久久久久久久久| 国模娜娜一区二区三区| 日韩欧美中文一区二区| 亚洲sss视频在线视频| 欧美一a一片一级一片| 国产精品毛片无遮挡高清| 韩国欧美一区二区| 欧美电视剧免费全集观看| 日本在线播放一区二区三区| 欧美日韩成人激情| 性欧美疯狂xxxxbbbb| 欧美午夜精品一区| 亚洲五月六月丁香激情| 欧美最新大片在线看| 亚洲综合免费观看高清完整版| 波多野结衣在线aⅴ中文字幕不卡| 国产欧美一区二区三区在线看蜜臀 | 极品美女销魂一区二区三区| 欧美日韩视频不卡| 一区二区三区美女| 成人网男人的天堂| 中文无字幕一区二区三区| 国产一区在线观看麻豆| 久久综合色之久久综合| 激情欧美一区二区三区在线观看| 日韩欧美在线不卡| 久草这里只有精品视频| 久久香蕉国产线看观看99| 国产在线精品一区二区| 国产欧美精品区一区二区三区 | 玉米视频成人免费看| 在线观看三级视频欧美| 亚洲午夜免费电影| 6080午夜不卡| 狠狠色狠狠色合久久伊人| 国产亚洲一区字幕| 99久久精品国产一区| 亚洲精品高清在线观看| 欧美日韩成人综合在线一区二区| 午夜亚洲国产au精品一区二区| 在线播放欧美女士性生活| 麻豆专区一区二区三区四区五区| 久久久青草青青国产亚洲免观| 有坂深雪av一区二区精品| 色综合久久久久综合99| 亚洲第一精品在线| 欧美人妇做爰xxxⅹ性高电影| 视频一区视频二区中文| 日韩色视频在线观看| 粉嫩在线一区二区三区视频| 亚洲人成小说网站色在线 | 91精品国产综合久久香蕉麻豆 | 91国产丝袜在线播放| 午夜视频在线观看一区二区三区| 日韩精品一区二区三区四区| 高清国产一区二区三区| 一二三四社区欧美黄| 日韩欧美的一区二区| av在线不卡电影| 日日夜夜一区二区| 久久免费电影网| 日本二三区不卡| 韩国一区二区三区| 一区二区成人在线观看| 欧美一区二区高清| jlzzjlzz亚洲女人18| 亚洲国产精品天堂| 久久久亚洲精品一区二区三区| 91啪九色porn原创视频在线观看| 免费久久99精品国产| 中文字幕制服丝袜一区二区三区 | 国产亚洲自拍一区| 欧美国产一区在线| 久久99久久99精品免视看婷婷| 91高清在线观看| 国产精品国产三级国产普通话三级 | 懂色av一区二区在线播放| 91久久一区二区| 日本精品免费观看高清观看| 精品久久久久久久久久久久久久久 | 欧美岛国在线观看| 久久精品国产成人一区二区三区 | 精品久久久久久久久久久久久久久 | 热久久免费视频| 国产精品欧美久久久久无广告| 欧美精品 国产精品| 成人av综合一区| 麻豆成人免费电影| 亚洲高清免费视频| 日本一区二区三区四区在线视频 | 亚洲一级二级三级在线免费观看| 久久麻豆一区二区| 制服丝袜亚洲播放| 一本大道久久a久久综合| 国产乱码精品一区二区三区五月婷 | 亚洲小说春色综合另类电影| 国产精品亲子乱子伦xxxx裸| 国产东北露脸精品视频| 中文在线资源观看网站视频免费不卡 | 国产一区 二区 三区一级| 天涯成人国产亚洲精品一区av| 亚洲男人天堂av网| 日本一区二区免费在线观看视频 | 亚洲成人在线网站| 亚洲激情av在线| 中文一区二区完整视频在线观看| 精品国产123| 欧美一级片免费看| 91精品免费在线观看| 欧美三级一区二区| eeuss鲁一区二区三区| 高清国产一区二区三区| 国产精品系列在线观看| 精品中文字幕一区二区| 麻豆精品在线看| 久久精品国产亚洲a| 日韩福利视频网|