MVC 6 引入了 Tag Helpers 作为@Html.EditorFor 的更好替代方案。可以创建自定义编辑器模板。也可以创建自定义标签助手。
但是,在创建 Tag Helper 时,需要通过 C# 代码(使用 TagBuilder 等)创建 HTML。对于复杂的 Tag Helpers,它不如使用 Razor 语法方便。
有什么方法可以让我从 Razor 页面创建自定义 Tag Helper?
MVC 6 引入了 Tag Helpers 作为@Html.EditorFor 的更好替代方案。可以创建自定义编辑器模板。也可以创建自定义标签助手。
但是,在创建 Tag Helper 时,需要通过 C# 代码(使用 TagBuilder 等)创建 HTML。对于复杂的 Tag Helpers,它不如使用 Razor 语法方便。
有什么方法可以让我从 Razor 页面创建自定义 Tag Helper?
s的美妙之TagHelper
处在于您可以以多种不同的方式混合 C# 和 Razor。因此,假设您有一个自定义 Razor 模板,例如:
CustomTagHelperTemplate.cshtml
@model User
<p>User name: @Model.Name</p>
<p>User id: @Model.Id</p>
你有模型:
namespace WebApplication1
{
public class User
{
public string Name { get; set; }
public int Id { get; set; }
}
}
和TagHelper
:
using System.IO;
using System.Threading.Tasks;
using Microsoft.AspNet.Mvc;
using Microsoft.AspNet.Mvc.Rendering;
using Microsoft.AspNet.Razor.Runtime.TagHelpers;
using Microsoft.Framework.WebEncoders;
namespace WebApplication1
{
public class UserTagHelper : TagHelper
{
private readonly HtmlHelper _htmlHelper;
private readonly IHtmlEncoder _htmlEncoder;
public UserTagHelper(IHtmlHelper htmlHelper, IHtmlEncoder htmlEncoder)
{
_htmlHelper = htmlHelper as HtmlHelper;
_htmlEncoder = htmlEncoder;
}
[ViewContext]
public ViewContext ViewContext
{
set
{
_htmlHelper.Contextualize(value);
}
}
public string Name { get; set; }
public int Id { get; set; }
public override async Task ProcessAsync(TagHelperContext context, TagHelperOutput output)
{
output.TagName = null;
output.SelfClosing = false;
var partial = await _htmlHelper.PartialAsync(
"CustomTagHelperTemplate",
new User
{
Name = Name,
Id = Id
});
var writer = new StringWriter();
partial.WriteTo(writer, _htmlEncoder);
output.Content.SetContent(writer.ToString());
}
}
}
然后您可以编写以下页面:
@addTagHelper "*, WebApplication1"
<user id="1234" name="John Doe" />
生成:
<p>User name: John Doe</p>
<p>User id: 1234</p>