Jest to możliwe do osiągnięcia wewnątrz pliku pomocniczego ze @functions
składnią, ale jeśli chcesz uzyskać czytelność w stylu maszynki do golenia, do której się odnosisz, będziesz musiał również wywołać zwykłego pomocnika, aby dopasować i zakończyć HTML.
Zwróć uwagę, że funkcje w pliku pomocnika są statyczne, więc nadal musisz przekazać wystąpienie HtmlHelper ze strony, jeśli zamierzasz użyć jej metod.
np. Views \ MyView.cshtml:
@MyHelper.DoSomething(Html, m=>m.Property1)
@MyHelper.DoSomething(Html, m=>m.Property2)
@MyHelper.DoSomething(Html, m=>m.Property3)
App_Code \ MyHelper.cshtml:
@using System.Web.Mvc;
@using System.Web.Mvc.Html;
@using System.Linq.Expressions;
@functions
{
public static HelperResult DoSomething<TModel, TItem>(HtmlHelper<TModel> html, Expression<Func<TModel, TItem>> expr)
{
return TheThingToDo(html.LabelFor(expr), html.EditorFor(expr), html.ValidationMessageFor(expr));
}
}
@helper TheThingToDo(MvcHtmlString label, MvcHtmlString textbox, MvcHtmlString validationMessage)
{
<p>
@label
<br />
@textbox
@validationMessage
</p>
}
...