ASP.NET Core Tag Helpers系列目录,这是第五篇,共五篇:

Tag Helper 组件 - 简介

之前我们已经在几个文章中谈到了Tag Helpers,这一次我们会讨论其它有关的事情。

在 ASP.NET Core 2 还为我们带来了一个新功能 - Tag Helper 组件

Tag Helper 组件负责生成或修改特定的HTML,它们与 Tag Helper 一起工作。

Tag Helper 将会运行您的 Tag Helper 组件。

Tag Helper 组件是动态地向HTML中添加内容最完美的选择。

要使您的Tag Helper组件运行,您需要设置一个特定的Tag Helper。这个Tag Helper需要从内置的抽象类继承 TagHelperComponentTagHelper

我知道,我知道这个命名非常令人困惑。

继承自 TagHelperComponentTagHelper 的类型将是一个 Tag Helper,它将执行与之匹配的 Tag Helper 组件。

步骤

我们首先创建一个新的 Tag Helper 组件。我们可以创建针对内置 headbody 标签的 Tag Helper 组件;从特殊类 TagHelperComponentTagHelper 继承的

Tag Helper,都可以创建 Tag Helper 组件。

我们来看一个例子。

我将从创建新的 Razor Pages 模板开始:

  1. dotnet new razor

我们按如下步骤让一个 Tag Helper 组件正常工作:

  1. 创建一个新的 Tag Helper 组件
  2. 将组件注入到DI
  3. 创建一个继承自TagHelperComponentTagHelper的 Tag Helper 类
  4. 将 Tag Helper 包含在_ViewImports.cshtml文件中

创建一个新的 Tag Helper 组件:

  1. public class ArticleTagHelperComponent : TagHelperComponent
  2. {
  3. public override Task ProcessAsync(TagHelperContext context, TagHelperOutput output)
  4. {
  5. if (string.Equals(context.TagName, "article", StringComparison.OrdinalIgnoreCase))
  6. {
  7. output.PostContent.AppendHtml("<script>console.log('ASP.NET Core - Love From Console');</script>");
  8. }
  9. return Task.CompletedTask;
  10. }
  11. }

如果您使用过 Tag Helper,那么您应该很熟悉。在示例中,继承自内置的TagHelperComponent抽象类,然后重写ProcessAsync方法。

我们需要将 Tag Helper 组件成为我们应用程序的一部分,将其注入到服务容器中:

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. services.AddTransient<ITagHelperComponent, ArticleTagHelperComponent>();
  4. services.AddMvc();
  5. }

现在我们可以使用创建的 Tag Helper 组件!

创建Tag Helper:

  1. [HtmlTargetElement("article")]
  2. [EditorBrowsable(EditorBrowsableState.Never)]
  3. public class ArticleTagHelperComponentTagHelper : TagHelperComponentTagHelper
  4. {
  5. public CodingBlastTagHelper(ITagHelperComponentManager componentManager, ILoggerFactory loggerFactory)
  6. : base(componentManager, loggerFactory)
  7. {
  8. }
  9. }

注意第一行,此 Tag Helper 助手的目标是HTML中的 所有 article 元素/标记。

为了让我们的应用程序知道这个Tag Helper,我们必须将其添加到_ViewImports.cshtml文件中:

  1. @using IntroTagHelperComponent
  2. @namespace IntroTagHelperComponent.Pages
  3. @addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers
  4. @addTagHelper SampleTagHelperComponent.ArticleTagHelperComponentTagHelper, SampleTagHelperComponent

要看到实际的效果,我们需要在代码中至少有一个 article 标签,所以,我们修改Index.cshtml页面:

  1. @model IndexModel
  2. @{
  3. ViewData["Title"] = "Home page";
  4. }
  5. <div></div>
  6. <article>
  7. TagHelperComponent will add stuff here.
  8. </article>

针对内置 Tag Helper 的 Tag Helper 组件

目前有两个内置的 Tag Helper 继承自TagHelperComponentTagHelper类,它们位于 Microsoft.AspNetCore.Mvc.TagHelpers 程序集中 。

这两个标签助手是 HeadTagHelperBodyTagHelper。它们使我们很容易将内容注入 headbody 中。我们所要做的是创建 Tag Helper 组件并将其注入我们的应用程序中。

这是 HeadTagHelper 的代码(aspnet/Mvc GitHub 仓库):

  1. // Copyright (c) .NET Foundation. All rights reserved.
  2. // Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
  3. using System.ComponentModel;
  4. using Microsoft.AspNetCore.Razor.TagHelpers;
  5. using Microsoft.Extensions.Logging;
  6. namespace Microsoft.AspNetCore.Mvc.Razor.TagHelpers
  7. {
  8. /// <summary>
  9. /// A <see cref="TagHelperComponentTagHelper"/> targeting the &lt;head&gt; HTML element.
  10. /// </summary>
  11. [HtmlTargetElement("head")]
  12. [EditorBrowsable(EditorBrowsableState.Never)]
  13. public class HeadTagHelper : TagHelperComponentTagHelper
  14. {
  15. /// <summary>
  16. /// Creates a new <see cref="HeadTagHelper"/>.
  17. /// </summary>
  18. /// <param name="manager">The <see cref="ITagHelperComponentManager"/> which contains the collection
  19. /// of <see cref="ITagHelperComponent"/>s.</param>
  20. /// <param name="loggerFactory">The <see cref="ILoggerFactory"/>.</param>
  21. public HeadTagHelper(ITagHelperComponentManager manager, ILoggerFactory loggerFactory)
  22. : base(manager, loggerFactory)
  23. {
  24. }
  25. }
  26. }

代码非常简单,它从 TagHelperComponentTagHelper 类继承,目标是 head HTML元素。

如果您查看默认的 _ViewImports.cshtml 文件内容,您将看到在默认情况下将包含这些内容:

  1. @using IntroTagHelperComponent
  2. @namespace IntroTagHelperComponent.Pages
  3. @addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers

我们可以将内置的 HeadTagHelper 使用我们的自定义 Tag Helper 组件来修改 head 标签:

我们添加一个 Tag Helper 组件,它将检查所有 head 标签:

  1. public class HeadTagHelperComponent : TagHelperComponent
  2. {
  3. public override Task ProcessAsync(TagHelperContext context, TagHelperOutput output)
  4. {
  5. if (string.Equals(context.TagName, "head", StringComparison.OrdinalIgnoreCase))
  6. {
  7. output.PostContent.AppendHtml("&lt;script&gt;console.log('head tag');&lt;/script&gt;");
  8. }
  9. return Task.CompletedTask;
  10. }
  11. }

当然,我们需要将添加的HeadTagHelperComponent注入到我们的应用程序:

  1. public void ConfigureServices(IServiceCollection services)
  2. {
  3. services.AddTransient<ITagHelperComponent, HeadTagHelperComponent>();
  4. services.AddMvc();
  5. }

代码

示例代码在GitHub - SampleTagHelperComponent

总结

  • Tag Helper 组件可用于动态地向HTML中添加内容
  • 特殊 Tag Helper(从 TagHelperComponentTagHelper 类继承)将执行所有匹配的 Tag Helper 组件

原文:《ASP.NET Core MVC – Tag Helper Components》https://codingblast.com/tag-helper-components/

翻译:Sweet Tang

本文地址:http://www.cnblogs.com/tdfblog/p/tag-helper-components-in-asp-net-core-mvc.html

欢迎转载,请在明显位置给出出处及链接。

ASP.NET Core MVC – Tag Helper 组件的更多相关文章

  1. ASP.NET Core MVC – Tag Helpers 介绍

    ASP.NET Core Tag Helpers系列目录,这是第一篇,共五篇: ASP.NET Core MVC – Tag Helpers 介绍 ASP.NET Core MVC – Caching ...

  2. ASP.NET Core MVC Tag Helpers 介绍

    简介 Tag Helpers 提供了在视图中更改和增强现有HTML元素的功能.将它们添加到视图中,会经过Razor模板引擎处理并创建一个HTML,之后再返回给浏览器.有一些Tag Helpers,其实 ...

  3. ASP.NET Core MVC 之视图组件(View Component)

    1.视图组件介绍 视图组件是 ASP.NET Core MVC 的新特性,类似于局部视图,但它更强大.视图组件不使用模型绑定,并且仅依赖于调用它时所提供的数据. 视图组件特点: 呈块状,而不是整个响应 ...

  4. ASP.NET Core - 关于Tag Helper值得了解的五点

    如果您开发过ASP.NET Core Web应用程序,您应该已经熟悉了Tag Helper.ASP.NET Core应用程序依赖Tag Helper来呈现表单和表单字段是很常见的.所以,一个视图通常包 ...

  5. ASP.NET Core MVC – Caching Tag Helpers

    简介 缓存可以大大提高应用程序加载时间和响应速度.我们可以使用缓存Tag Helpers缓存不会频繁更改的HTML内容. 在上一篇文章中,我们谈到了Tag Helpers,演示Tag Helpers能 ...

  6. ASP.NET Core MVC – Form Tag Helpers

    ASP.NET Core Tag Helpers系列目录 ASP.NET Core MVC Tag Helpers 介绍 ASP.NET Core MVC – Caching Tag Helpers ...

  7. ASP.NET Core MVC – 自定义 Tag Helpers

    ASP.NET Core Tag Helpers系列目录,共四篇: ASP.NET Core MVC Tag Helpers 介绍 ASP.NET Core MVC – Caching Tag Hel ...

  8. asp.net core mvc View Component 应用

    ViewComponent 1.View 组件介绍 在ASP.NET CORE MVC中,View组件有点类似于partial views,但是他们更强大,View组件不能使用model bindin ...

  9. [asp.net core]定义Tag Helpers

    原文地址 https://docs.microsoft.com/en-us/aspnet/core/mvc/views/tag-helpers/authoring Getting started wi ...

随机推荐

  1. shell脚本中字符串的常见操作及"command not found"报错处理(附源码)

    简介 昨天在通过shell脚本实现一个功能的时候,由于对shell处理字符串的方法有些不熟悉导致花了不少时间也犯了很多错误,因此将昨日的一些错误记录下来,避免以后再犯. 字符串的定义与赋值 # 定义S ...

  2. 西电2017ACM网络赛

    #include<bits/stdc++.h> using namespace std; typedef long long LL; #define ms(a,x) memset(a,x, ...

  3. (转)使用BigDecimal进行精确运算

    场景:在进行支付业务的金额计算时,通常采用BigDecimal类型的数据,并没有看到常见的int double类型,所以有必要好好学习下BigDecimal的常用用法. 1 误区 首先我们先来看如下代 ...

  4. (转)java.util.Scanner应用详解

    java.util.Scanner应用详解   java.util.Scanner是Java5的新特征,主要功能是简化文本扫描.这个类最实用的地方表现在获取控制台输入,其他的功能都很鸡肋,尽管Java ...

  5. (转)浅析CSS——元素重叠及position定位的z-index顺序

    多次在项目中遇到html页面元素的非期待重叠错误,多数还是position定位情况下z-index的问题.其实每次解决类似问题思路大致都是一样的,说到底还是对z-index的理解比较模糊,可以解决问题 ...

  6. 【JAVASCRIPT】React学习-JSX 语法

    摘要 react 学习包括几个部分: 文本渲染 JSX 语法 组件化思想 数据流 JSX 语法 1. 定义 JSX 是javascript + xml 的合集,我们可以将javascript 与 ht ...

  7. 【MYSQL】SQL 的join 区别

    ----------------------INNER JOIN---------------------------  1. 三表联合查询 select XX,XX  from a , b , c  ...

  8. 【原创】07. ajax请求,解决sendRedirect 无效

    介绍: 后台基于旧代码用的Filter验证,若 Session过期,则跳转登陆页面 前台框架:EasyUI 问题: 最初后台验证不通过: 1 httpServletResponse.sendRedir ...

  9. webpack开发与生产环境配置

    前言 作者去年就开始使用webpack, 最早的接触就来自于vue-cli.那个时候工作重点主要也是 vue 的使用,对webpack的配置是知之甚少,期间有问题也是询问大牛 @吕大豹.顺便说一句,对 ...

  10. 深度学习:Keras入门(二)之卷积神经网络(CNN)

    说明:这篇文章需要有一些相关的基础知识,否则看起来可能比较吃力. 1.卷积与神经元 1.1 什么是卷积? 简单来说,卷积(或内积)就是一种先把对应位置相乘然后再把结果相加的运算.(具体含义或者数学公式 ...