Share via


Templated Razor Delegates combined with Partial Views

I was with a customer in Germany this week, and just before I left one of the (rather talented I might say) developers asked me about passing markup into an HtmlHelper extension. It turns out this is pretty easy, as covered by Phil Haack under Templated Razor Delegates. However, I particularly like keeping my HTML markup in cshtml files. It’s just easier to maintain. So I combined Phil’s post with the use of a partial view. The nice simple HtmlHelper extension looks like this;

    1:  public static MvcHtmlString Region<TModel>( 
    2:     this HtmlHelper<TModel> html, 
    3:     Func<TModel, object> content) 
    4:  { 
    5:     var result = content(html.ViewData.Model); 
    6:     return html.Partial("_Region", result); 
    7:  } 

This accepts a Func<TModel, object> which is the Templated Razor Delegate. This is quite simply a snippet of Razor syntax that is executed to return markup as “result”.

    1:  @Html.Region(@<text>@Model.WelcomeMessage</text>)

I’ve combined my HtmlHelper extension with a partial view named _Region, stored in the Shared folder;

    1:  <fieldset class="demoregion"> 
    2:      <legend>A Region</legend> 
    3:      <div> 
    4:          @Model 
    5:      </div> 
    6:  </fieldset>

This would be way neater if I could use an @helper under App_Code, but in MVC 3 that feature doesn’t support using HtmlHelper, so you couldn’t use Html.Textbox in the template, for example.

The code is attached – easy huh?

EmbeddedContent.zip