Sometimes its useful to be able target html elements on a particular page or you want to have specific styling according to a particular area, controller or action.

Here is a small extension to use route data to do just that.

namespace Antix.Web.Mvc {

 public static class Extentions {

  /// <summary>
  /// <para>Get a string from the route data</para>
  /// </summary>
  public static string RouteString(
      this ViewContext context, string template) {

   foreach (var value in context.RouteData.Values) {

    template = template.Replace(string.Format("{{{0}}}", 
            value.Value == null
                ? string.Empty
                : value.Value.ToString().ToLower());

   return template;

Making sure that the extension is in scope;
by importing on your page

<%@ Import Namespace="Antix.Web.Mvc"%>

or adding to you web.config

    <add namespace="Antix.Web.Mvc"/>

Call the function to retrieve the route data in a particular format like so...

<body class="<%= ViewContext.RouteString("{controller}_{action}") %>">

I've used this in the master page of my site to identify a page Body tag by controller and action.

<blog class="home_blogentry">
comments powered by Disqus

On Twitter Follow MrAntix on Twitter

JobsLondon1 22 minutes ago

C# MVC Developer Job London

or_exchange 29 minutes ago

RT @natebrix: [Blog Post] Timeseries analysis using @FrontlineSolver, #Excel, and #PowerQuery:

diederikkrols 32 minutes ago

RT @U2UConsult: The Identity Hub is now available as an add-on in Windows Azure. #identitymanagement @msdev @vibronet

AzureNews 33 minutes ago

RT @ProgrammerGuide: Learn to Deploy Windows #Azure Websites | MVC Windows Azure Video Tutorial: In this… http://t.c

ProgrammerGuide 33 minutes ago

Learn to Deploy Windows #Azure Websites | MVC Windows Azure Video Tutorial: In this…