MVC2中活动视图的亮点?

Kri*_*anB 0 css navigation asp.net asp.net-mvc-2

好的,我的网站是www.kristianbak.com.

我有一个名为的css类activebutton.我希望每当另一个视图处于活动状态时进行更改.目前它只是在HTML(sitemaster)中硬编码.

谁有好主意?

Dar*_*rov 5

您可以测试当前操作,如果匹配则应用CSS类:

<% if (ViewContext.RouteData.GetRequiredString("action") == "About") { %>
    ... highlight here
<% } %>
Run Code Online (Sandbox Code Playgroud)

更好的是我会写一个HTML帮助器来生成菜单:

public static MvcHtmlString MenuItem(
    this HtmlHelper htmlHelper, 
    string text,
    string action, 
    string controller
)
{
    var li = new TagBuilder("li");
    var routeData = htmlHelper.ViewContext.RouteData;
    var currentAction = routeData.GetRequiredString("action");
    var currentController = routeData.GetRequiredString("controller");
    if (string.Equals(currentAction, action, StringComparison.OrdinalIgnoreCase) &&
        string.Equals(currentController, controller, StringComparison.OrdinalIgnoreCase))
    {
        li.AddCssClass("active");
    }
    li.InnerHtml = htmlHelper.ActionLink(text, action, controller).ToHtmlString();
    return MvcHtmlString.Create(li.ToString());
}
Run Code Online (Sandbox Code Playgroud)

然后像这样使用它:

<ul>
    <%= Html.MenuItem("Home", "Home", "Home") %>
    <%= Html.MenuItem("About Me", "About", "Home") %>
    <%= Html.MenuItem("My Work", "Work", "Home") %>
    <%= Html.MenuItem("Blog", "Index", "Blog") %>
    ...
</ul>
Run Code Online (Sandbox Code Playgroud)

active如果当前请求与链接的操作和控制器匹配,则会将类添加到锚点.