iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >ASP.NET Core MVC中如何使用Tag Helper组件
  • 402
分享到

ASP.NET Core MVC中如何使用Tag Helper组件

2023-06-29 06:06:29 402人浏览 八月长安
摘要

这篇文章主要介绍asp.net Core mvc中如何使用Tag Helper组件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Tag Helper 组件 - 简介在 ASP.net c

这篇文章主要介绍asp.net Core mvc中如何使用Tag Helper组件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

Tag Helper 组件 - 简介

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 组件。我们可以创建针对内置 head 和 body 标签的 Tag Helper 组件;从特殊类 TagHelperComponentTagHelper 继承的
Tag Helper,都可以创建 Tag Helper 组件。

我们来看一个例子。

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

    dotnet new razor

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

  • 创建一个新的 Tag Helper 组件

  • 将组件注入到DI

  • 创建一个继承自TagHelperComponentTagHelper的 Tag Helper 类

  • 将 Tag Helper 包含在_ViewImports.cshtml文件中

创建一个新的 Tag Helper 组件:

    public class ArticleTagHelperComponent : TagHelperComponent    {        public override Task ProcessAsync(TagHelperContext context, TagHelperOutput output)        {            if (string.Equals(context.TagName, "article", StrinGComparison.OrdinalIgnoreCase))            {                output.PostContent.AppendHtml("<script>console.log('ASP.net Core - Love From Console');</script>");            }            return Task.CompletedTask;        }    }

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

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

    public void ConfigureServices(IServiceCollection services)    {        services.AddTransient<ITagHelperComponent, ArticleTagHelperComponent>();        services.AddMvc();    }

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

创建Tag Helper:

    [HtmlTargetElement("article")]    [EditorBrowsable(EditorBrowsableState.Never)]    public class ArticleTagHelperComponentTagHelper : TagHelperComponentTagHelper    {        public codingBlastTagHelper(ITagHelperComponentManager componentManager, ILoggerFactory loggerFactory)            : base(componentManager, loggerFactory)        {        }    }

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

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

    @using IntroTagHelperComponent    @namespace IntroTagHelperComponent.Pages    @addTagHelper *, Microsoft.Aspnetcore.Mvc.TagHelpers    @addTagHelper SampleTagHelperComponent.ArticleTagHelperComponentTagHelper, SampleTagHelperComponent

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

@model IndexModel@{    ViewData["Title"] = "Home page";} <div></div> <article>    TagHelperComponent will add stuff here.</article>

针对内置 Tag Helper 的 Tag Helper 组件

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

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

// Copyright (c) .NET Foundation. All rights reserved.// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license infORMation.using System.ComponentModel;using Microsoft.AspNetCore.Razor.TagHelpers;using Microsoft.Extensions.Logging;namespace Microsoft.AspNetCore.Mvc.Razor.TagHelpers{    /// <summary>    /// A <see cref="TagHelperComponentTagHelper"/> targeting the &lt;head&gt; HTML element.    /// </summary>    [HtmlTargetElement("head")]    [EditorBrowsable(EditorBrowsableState.Never)]    public class HeadTagHelper : TagHelperComponentTagHelper    {        /// <summary>        /// Creates a new <see cref="HeadTagHelper"/>.        /// </summary>        /// <param name="manager">The <see cref="ITagHelperComponentManager"/> which contains the collection        /// of <see cref="ITagHelperComponent"/>s.</param>        /// <param name="loggerFactory">The <see cref="ILoggerFactory"/>.</param>        public HeadTagHelper(ITagHelperComponentManager manager, ILoggerFactory loggerFactory)            : base(manager, loggerFactory)        {        }    }}

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

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

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

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

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

public class HeadTagHelperComponent : TagHelperComponent{    public override Task ProcessAsync(TagHelperContext context, TagHelperOutput output)    {        if (string.Equals(context.TagName, "head", StringComparison.OrdinalIgnoreCase))        {            output.PostContent.AppendHtml("<script>console.log('head tag');</script>");        }        return Task.CompletedTask;    }}

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

    public void ConfigureServices(IServiceCollection services)    {        services.AddTransient<ITagHelperComponent, HeadTagHelperComponent>();        services.AddMvc();    }

总结

  • Tag Helper 组件可用于动态地向HTML中添加内容

  • 特殊 Tag Helper(从 TagHelperComponentTagHelper 类继承)将执行所有匹配的 Tag Helper 组件

以上是“ASP.NET Core MVC中如何使用Tag Helper组件”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: ASP.NET Core MVC中如何使用Tag Helper组件

本文链接: https://www.lsjlt.com/news/323099.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • ASP.NET Core MVC中如何使用Tag Helper组件
    这篇文章主要介绍ASP.NET Core MVC中如何使用Tag Helper组件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!Tag Helper 组件 - 简介在 ASP.NET C...
    99+
    2023-06-29
  • ASP.NET Core MVC中使用Tag Helper组件
    Tag Helper 组件 - 简介 之前我们已经在几个文章中谈到了Tag Helpers,这一次我们会讨论其它有关的事情。 在 ASP.NET Core 2 还为我们带来了一个新功...
    99+
    2024-04-02
  • ASP.NET Core MVC中Form Tag Helpers怎么用
    这篇文章主要介绍了ASP.NET Core MVC中Form Tag Helpers怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下...
    99+
    2023-06-29
  • ASP.NET Core MVC中Tag Helpers用法介绍
    简介 Tag Helpers 提供了在视图中更改和增强现有HTML元素的功能。将它们添加到视图中,会经过Razor模板引擎处理并创建一个HTML,之后再返回给浏览器。有一些Tag H...
    99+
    2024-04-02
  • ASP.NET Core MVC如何自定义Tag Helpers
    这篇文章主要为大家展示了“ASP.NET Core MVC如何自定义Tag Helpers”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“ASP.NET C...
    99+
    2023-06-29
  • ASP.NET Core MVC中Form Tag Helpers用法介绍
    简介 我们已经介绍过Tag Helpers以及一些最常用的Tag Helpers,也谈到了缓存Tag Helpers。在这篇文章中,我们将讨论表单Tag Helpers。 HTML或...
    99+
    2024-04-02
  • ASP.NET Core使用AutoMapper组件
    1.什么是AutoMapper? AutoMapper是一个对象-对象映射器。对象-对象映射通过将一种类型的输入对象转换为另一种类型的输出对象来工作。使AutoMapper变得有趣的...
    99+
    2024-04-02
  • ASP.NET Core中间件如何使用
    今天小编给大家分享一下ASP.NET Core中间件如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1.前言...
    99+
    2023-06-29
  • ASP.NET Core MVC中的模型怎么使用
    本篇内容介绍了“ASP.NET Core MVC中的模型怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.模型绑...
    99+
    2023-06-30
  • ASP.NET MVC中如何使用MvcPager
    这篇“ASP.NET MVC中如何使用MvcPager”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来...
    99+
    2024-04-02
  • ASP.NET Core 中FromServices如何使用
    本篇文章给大家分享的是有关 ASP.NET Core 中FromServices如何使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。构造函数...
    99+
    2024-04-02
  • 如何使用ASP.NET Core 配置文件
    目录前言Json配置文件的使用RedisHelper类XML配置文件的使用前言 在ASP.NET ,我们使用XML格式的.Config文件来作为配置文件,而在ASP.NET Core...
    99+
    2024-04-02
  • 如何在ASP.NET Core中使用HttpClientFactory
    目录为什么要使用 HttpClientFactory 使用 HttpClientFactory 注入 Controller ASP.Net Core 是一个开源的,跨平台的,轻量级模...
    99+
    2024-04-02
  • Serilog如何在ASP.Net Core中使用
    本篇文章为大家展示了Serilog如何在ASP.Net Core中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。安装 Serilog使用 Visual Studio 新建 ASP.Net Cor...
    99+
    2023-06-14
  • 如何在ASP.NET Core中使用ViewComponent
    目录前言自定义一个组件ViewComponent特性Taghelper方式Reference前言 在之前的开发过程中,我们对于应用或者说使用一些小的组件,通常使用分布页(parti...
    99+
    2024-04-02
  • ASP.NET Core中的Caching组件怎么用
    本文小编为大家详细介绍“ASP.NET Core中的Caching组件怎么用”,内容详细,步骤清晰,细节处理妥当,希望这篇“ASP.NET Core中的Caching组件怎么用”文章能帮助大家解决疑惑,下面跟着小编的思路...
    99+
    2023-06-30
  • 如何在ASP.Net Core中使用Serilog
    目录安装 Serilog使用 Serilog Sink使用 Serilog 替换原生的 Logger记录日志的一个作用就是方便对应用程序进行跟踪和排错调查,在实际应用上都是引入 日志...
    99+
    2024-04-02
  • 如何在Asp.Net Core中使用Refit
    本篇文章给大家分享的是有关如何在Asp.Net Core中使用Refit,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。ASP.NET 是什么ASP.NET 是开源,跨平台,高性...
    99+
    2023-06-07
  • ASP.NET中Route组件如何使用
    这篇文章将为大家详细讲解有关ASP.NET中Route组件如何使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。RouteBase职责明确:从请求中获取数据,及根据数据生成虚拟路径。它只有两...
    99+
    2023-06-17
  • ASP.NET中如何使用 CheckBoxList组件
    ASP.NET中如何使用 CheckBoxList组件,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。假定有一个CheckBoxList组件和有十个CheckBox组件,并且这个...
    99+
    2023-06-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作