如何为razor创建自定义标签助手

本文关键字:标签 自定义 创建 razor | 更新日期: 2023-09-27 17:49:52

我试图在MVC 6中创建一个自定义标签助手,但无法使其工作。

这是我在web应用程序项目中定义的演示标签助手类。

namespace Microsoft.AspNet.Mvc.TagHelpers
{
    [TargetElement("demo", Attributes = CustomAttributeName)]
    public class DemoTagHelper : TagHelper
    {
        private const string CustomAttributeName = "asp-custom";
        [HtmlAttributeName(CustomAttributeName)]
        public string Custom { get; set; }
        public string Value { get; set; }

        public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            output.TagName = "div";
            output.Attributes["foo"] = "bar";
        }
    }
}

在我的视图中是这样使用的:

<demo asp-custom="hello world!">
    Please work this time :)
</demo>

我尝试了很多东西。删除TargetElement属性或更改命名空间。没有什么变化……结果还是一样的。

顺便说一下,我的 microsoft . asp.net . mvc。TagHelpers 版本是 6.0.0-beta4

也许我必须在某个地方注册我的标签助手?我查看了MVC源代码,他们没有在任何地方引用自己的标记帮助器。所以我认为不需要注册。

问题在哪里?

如何为razor创建自定义标签助手

您可以通过向Views目录中的_ViewImports.cshtml文件添加addTagHelper指令来启用自定义标记的TagHelper处理:

@addTagHelper "*, YourMvcAssembly"

@yilmaz还需要添加对Microsoft.AspNet.Tooling.Razor的引用,详见下面的评论

这就是我目前为自定义标记帮助器所做的工作。我将其更改为针对演示元素。试一试:

namespace TestingTagHelpers.TagHelpers
{
    using Microsoft.AspNet.Razor.Runtime.TagHelpers;
    using System;
    /// <summary>
    /// <see cref="ITagHelper"/> implementation targeting &lt;demo&gt; elements.
    /// </summary>
    //[TargetElement("demo")]
    public class DemoTagHelper : TagHelper
    {
        public override void Process(TagHelperContext context, TagHelperOutput output)
        {
            var childContent = context.GetChildContentAsync().Result;
            string demoContent = childContent.GetContent();
            string demo = context.AllAttributes["asp-custom"].ToString();
            output.TagName = "div";
            output.Attributes.Clear();
            output.Attributes["data-custom"] = demo;
            output.Content.SetContent(demoContent);
        }
    }
}