欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2016年07月26日 09:35:18   作者:神牛步行3  
這篇文章主要介紹了NET Core TagHelper實(shí)現(xiàn)分頁(yè)標(biāo)簽,講述實(shí)現(xiàn)一個(gè)簡(jiǎn)單分頁(yè)和總要注意步奏,感興趣的小伙伴們可以參考一下

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

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

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

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

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

5.效果展示

下面一步一個(gè)腳印的來(lái)分享:

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

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

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

各位需要注意版本一直,不然還原程序包的時(shí)候會(huì)出錯(cuò)

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

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

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

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

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

咋們?cè)谧远x標(biāo)簽類(lèi)中定義個(gè)屬性(這里因?yàn)橐龇猪?yè)所以這里直接定義個(gè)分頁(yè)參數(shù)的對(duì)應(yīng)屬性類(lèi)當(dāng)做標(biāo)簽類(lèi)的屬性),分頁(yè)參數(shù)類(lèi)如下:

/// <summary>
 /// 分頁(yè)option屬性
 /// </summary>
 public class MoPagerOption
 {
  /// <summary>
  /// 當(dāng)前頁(yè) 必傳
  /// </summary>
  public int CurrentPage { get; set; }
  /// <summary>
  /// 總條數(shù) 必傳
  /// </summary>
  public int Total { get; set; }

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

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

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

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

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

注意:

*單詞大小寫(xiě)

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

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

這里用到上面第3點(diǎn)的屬性節(jié)點(diǎn)來(lái)傳遞參數(shù),先看一下咋們?cè)贑ontroller定義的列表數(shù)據(jù)和分頁(yè)數(shù)據(jù)封裝如下:

// GET: Articles
  public async Task<IActionResult> Index(int id = 1)
  {

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

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

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

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

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

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

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 分頁(yè)擴(kuò)展 PageExtend

 /// <summary>
 /// 分頁(yè)option屬性
 /// </summary>
 public class MoPagerOption
 {
  /// <summary>
  /// 當(dāng)前頁(yè) 必傳
  /// </summary>
  public int CurrentPage { get; set; }
  /// <summary>
  /// 總條數(shù) 必傳
  /// </summary>
  public int Total { get; set; }

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

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

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

 /// <summary>
 /// 分頁(yè)標(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; }

   //總頁(yè)數(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)造分頁(yè)樣式
   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.效果展示

分頁(yè)效果:

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

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

相關(guān)文章

  • ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解

    ASP.NET Core中修改配置文件后自動(dòng)加載新配置的方法詳解

    這篇文章主要給大家介紹了關(guān)于ASP.NET Core中修改配置文件后自動(dòng)加載新配置的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用ASP.NET Core具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • ASP.NET MVC5驗(yàn)證系列之服務(wù)端驗(yàn)證

    ASP.NET MVC5驗(yàn)證系列之服務(wù)端驗(yàn)證

    這篇文章主要為大家詳細(xì)介紹了ASP.NET MVC5驗(yàn)證系列之服務(wù)端驗(yàn)證,使用兩種方法來(lái)驗(yàn)證數(shù)據(jù)的合法性,手動(dòng)驗(yàn)證的方式和數(shù)據(jù)注解來(lái)進(jìn)行服務(wù)端驗(yàn)證,感興趣的小伙伴們可以參考一下
    2016-07-07
  • ASP.NET?Core自定義中間件的方式詳解

    ASP.NET?Core自定義中間件的方式詳解

    這篇文章主要介紹了ASP.NET?Core自定義中間件的方式,雖然ASP.NET?Core為我們提供了一組豐富的內(nèi)置中間件,但有些時(shí)候我們可能會(huì)需要自定義一些中間件,將其穿插到管道中,以便滿足我們特定業(yè)務(wù)場(chǎng)景的需求,所以本文將介紹3種方式來(lái)滿足自定義中間件的需求
    2022-08-08
  • asp.net運(yùn)行原理 詳解

    asp.net運(yùn)行原理 詳解

    當(dāng)我們通過(guò)瀏覽器向ASP.NET 2.0網(wǎng)站的一個(gè)asp.net頁(yè)面發(fā)起請(qǐng)求時(shí),在服務(wù)器端首先是IIS收到請(qǐng)求,IIS一看是asp.net頁(yè)面,心里很開(kāi)心,因?yàn)檫@個(gè)請(qǐng)求不用它處理,交給ASP.NET ISAPI就行了
    2012-04-04
  • asp.net Page.EnableEventValidation 屬性驗(yàn)證服務(wù)器控件的回發(fā)和回調(diào)事件出現(xiàn)的錯(cuò)誤

    asp.net Page.EnableEventValidation 屬性驗(yàn)證服務(wù)器控件的回發(fā)和回調(diào)事件出現(xiàn)的錯(cuò)誤

    Page.EnableEventValidation 屬性驗(yàn)證服務(wù)器控件的回發(fā)和回調(diào)事件出現(xiàn)的錯(cuò)誤前兩天用jQuery做了一個(gè)包含DropDownList聯(lián)動(dòng)的頁(yè)面,數(shù)據(jù)通過(guò)Ajax請(qǐng)求得到的。
    2010-10-10
  • 請(qǐng)求如何進(jìn)入ASP.NET MVC框架

    請(qǐng)求如何進(jìn)入ASP.NET MVC框架

    這篇文章主要介紹了請(qǐng)求如何進(jìn)入ASP.NET MVC框架的實(shí)現(xiàn)過(guò)程,感興趣的小伙伴們可以參考一下
    2016-04-04
  • ASP.NET操作Word的IIS權(quán)限設(shè)置

    ASP.NET操作Word的IIS權(quán)限設(shè)置

    檢索 COM 類(lèi)工廠中 CLSID 為 {00024500-0000-0000-C000-000000000046} 的組件時(shí)失敗,原因是出現(xiàn)以下錯(cuò)誤: 80070005。
    2011-02-02
  • 詳解ASP.NET Core 網(wǎng)站發(fā)布到Linux服務(wù)器

    詳解ASP.NET Core 網(wǎng)站發(fā)布到Linux服務(wù)器

    本篇文章主要介紹了ASP.NET Core 網(wǎng)站發(fā)布到Linux服務(wù)器 。具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。
    2017-04-04
  • asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)

    asp.net使用AJAX實(shí)現(xiàn)無(wú)刷新分頁(yè)

    AJAX(Asynchronous JavaScript and XML)是一種進(jìn)行頁(yè)面局部異步刷新的技術(shù)。用AJAX向服務(wù)器發(fā)送請(qǐng)求和獲得服務(wù)器返回的數(shù)據(jù)并且更新到界面中,不是整個(gè)頁(yè)面刷新,而是在頁(yè)面中使用Js創(chuàng)建XMLHTTPRequest對(duì)象來(lái)向服務(wù)器發(fā)出請(qǐng)求以及獲得返回的數(shù)據(jù)。
    2014-11-11
  • WPF使用StackPanel棧面板布局

    WPF使用StackPanel棧面板布局

    這篇文章介紹了WPF使用StackPanel棧面板布局的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02

最新評(píng)論