努力寻找问题的答案,因为我不确定剃刀标签是什么“类型”。
从本质上讲,我想创建一个可以按照以下方式执行操作的助手:
public static xxxxxxx ScriptTag(this HtmlHelper htmlHelper, string url)
{
return @<script type="text/javascript" src="@Url.Content("~/" + url)" />;
}
我想要这样做的原因是,我正在实现this post中概述的扩展方法。
基本上不必做:
@Html.Resource(@<script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" type="text/javascript"></script>, "js")`
我希望能够做到:
@Html.Resource(Html.ScriptTag("Scripts/jquery-1.4.4.min.js"), "js");
我是在这里超越星空还是可能?
克里斯
最佳答案
我在您的ScriptTag
助手(js
)中看不到第二个参数的用法。该帮助程序称为ScriptTag,因此很明显它将渲染脚本。另外,当您可以直接拥有以下内容时,为什么需要这样的两个嵌套帮助器:
@Html.Resource("Scripts/jquery-1.4.4.min.js", "js")
但是无论如何,如果您需要这样的语法,则可以使用Razor Templated Delegates:
public static class HtmlExtensions
{
public static HelperResult ScriptTag(this HtmlHelper htmlHelper, string url, string type)
{
var urlHelper = new UrlHelper(htmlHelper.ViewContext.RequestContext);
var script = new TagBuilder("script");
script.Attributes["type"] = "text/javascript";
script.Attributes["src"] = urlHelper.Content("~/" + url);
return new HelperResult(writer =>
{
writer.Write(script.ToString(TagRenderMode.Normal));
});
}
public static IHtmlString Resource(this HtmlHelper htmlHelper, HelperResult renderer)
{
return renderer;
}
}
如我们所见,在这种情况下,
Resource
扩展方法不会带来太多价值。