NET Core TagHelper实现分页标签

 更新时间:2016年07月26日 09:35:18   作者:神牛步行3  
这篇文章主要介绍了NET Core TagHelper实现分页标签,讲述实现一个简单分页和总要注意步奏,感兴趣的小伙伴们可以参考一下

这里将要和大家分享的是学习总结使用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 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"
   };

   //分页参数
   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元素:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • ASP.NET Core MVC中的标签助手(TagHelper)用法

    ASP.NET Core MVC中的标签助手(TagHelper)用法

    这篇文章介绍了ASP.NET Core MVC中标签助手(TagHelper)的用法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • Asp.Net Oracle数据的通用操作类

    Asp.Net Oracle数据的通用操作类

    Asp.Net连接Oracle数据的通用操作类并且利用它对数据库查询、汇总、更新等操作演示
    2009-12-12
  • asp.net 临时数据保存实现代码

    asp.net 临时数据保存实现代码

    在一个程序运行的时候往往我们会回到上一个页面,或者我们会需要当时留在这个页面的临时数据,例如,我们用百度搜索“脚本”之后我们会看到很多那啥我就不再说了啊!然后我们返回本来页面在文本框内会有“脚本”的字样,我们一下代码段就是实现这个功能
    2012-04-04
  • Entity Framework Core生成列并跟踪列记录

    Entity Framework Core生成列并跟踪列记录

    这篇文章介绍了Entity Framework Core生成列并跟踪列记录的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02
  • Asp.Net中的数据源概述与配置及实例代码

    Asp.Net中的数据源概述与配置及实例代码

    数据绑定分为数据源和数据绑定控件两部分,数据绑定控件通过数据源来获得数据;接下来本文将分别介绍下数据源/数据绑定控件/ObjectDataSource
    2013-02-02
  • ASP.NET XmlDocument类详解

    ASP.NET XmlDocument类详解

    这篇文章主要介绍了ASP.NET XmlDocument类详解,本文讲解了XmlDocument的属性、XmlDocument的方法、XmlDocument的事件、XmlDocument的使用实例等内容,需要的朋友可以参考下
    2015-05-05
  • Json日期格式问题的四种解决方法(超详细)

    Json日期格式问题的四种解决方法(超详细)

    这篇文章主要介绍了Json日期格式问题的四种解决方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03
  • ASP.NET Cookie 操作实现

    ASP.NET Cookie 操作实现

    本节中的主题描述如何在 ASP.NET Web 应用程序中创建 Cookie。Cookie 是一些小的文本文件,服务器和浏览器在收到每个页请求时交换它们,您还可以使用这些小文本文件来存储帮助针对每个用户自定义您的应用程序的信息。
    2009-11-11
  • 一文轻松了解ASP.NET与ASP.NET Core多环境配置对比

    一文轻松了解ASP.NET与ASP.NET Core多环境配置对比

    ASP.NET Core支持在多个环境中管理应用程序,如开发(Development),预演(Staging)和生产(Production),下面这篇文章主要给大家介绍了关于ASP.NET与ASP.NET Core多环境配置对比 的相关资料,需要的朋友可以参考下
    2022-04-04
  • ASP.NET 上传文件到共享文件夹的示例

    ASP.NET 上传文件到共享文件夹的示例

    这篇文章主要介绍了ASP.NET 上传文件到共享文件夹的示例,帮助大家更好的理解和学习使用.net技术,感兴趣的朋友可以了解下
    2021-04-04

最新评论