TagHelper用于<meta />标签

时间:2017-05-29 14:44:51

标签: asp.net-core tag-helpers

我正在尝试使用TagHelper来重写我网站中的一些meta标记。

对于具有以下属性的每个meta代码:data-data-main,data-src,我想替换其中一个属性的值。

例如,这是原始的:

<meta name="js" content="script" data-async="true" data-data-main="requirejs/product-overview/init" data-src="/js/libs/require.js">

我想把它变成这个:

<meta name="js" content="script" data-async="true" data-data-main="http://cdn.website.nl/8c87f33ca5acc7fdb9186d6a497642784685aabade058d3530bdf6d30168cfcd.js" data-src="/js/libs/require.js">

唯一改变的是data-data-main属性:它现在指向CDN上的URL而不是本地文件。

我制作了一个自定义TagHelper来帮助我实现这一目标:

[HtmlTargetElement("meta", Attributes = "[data-data-main],[data-src]")]
public class MetaScriptTagHelper : TagHelper
{
    private readonly BluenotionSiteSettings _bnSiteSettings;
    private readonly SiteTemplateService _templateService;

    public MetaScriptTagHelper(BluenotionSiteSettingsFiller bnSiteSettingsFiller, SiteTemplateService templateService)
    {
        _bnSiteSettings = bnSiteSettingsFiller.Create(HttpContext);
        _templateService = templateService;
    }

    [ViewContext]
    public ViewContext ViewContext { get; set; }

    private HttpContext HttpContext => ViewContext.HttpContext;

    public override void Process(
        TagHelperContext context, TagHelperOutput output)
    {
        var dataDataMainValue = context.AllAttributes["data-data-main"].Value.ToString();
        var localPath = @".\wwwroot\js\" + dataDataMainValue.Replace('/', '\\') + ".js";
        var siteTemplateId = _templateService.SiteTemplateBySiteIdAsync(_bnSiteSettings.SiteId);
        var cdnPath = _templateService.GetResourceByName(siteTemplateId, localPath);
        output.Attributes.Add("data-data-main", cdnPath);
    }
}

可悲的是,它返回了一个例外:

  

发现格式错误的'meta'标记助手。标记助手必须具有开始和结束标记或自行关闭。

(没有进一步的堆栈跟踪/信息来指示格式错误的元标记是什么)

我无法调试格式错误的meta标记是什么,所以我不知道问题出在哪里。有什么建议吗?

1 个答案:

答案 0 :(得分:1)

好吧,在我发布问题之前没有检查过这个问题我感到非常愚蠢,但很明显,正是输入TagHelper搞得一团糟。

它说Tag helpers must have a start and end tag or be self closing.显然,这意味着进来的meta元素必须有一个结束标记或自我关闭,这(如我之前/之后的样本所示)my {{1元素没有。

所以要修复,我只需要让输入meta代码自动关闭(即在结束meta之前添加/):

>