文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-06-29 06:44

关注

这篇文章主要介绍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 组件:

    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();    }

总结

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯