0

解決策を探していたので、いくつかの記事を読みました。それらはすべて、ハードコーディングされた、または HTML ヘルパーの代替手段を好むようでした。ただし、シンプルでデータベース駆動型のものが必要でした。これが私の最善の解決策です(私が回答として提出しました)。

他の記事の解決策は次のとおりです。

4

3 に答える 3

1

次のように、コントローラーの 1 つから TempData を渡すだけです。

TempData("CurrentPage") = "Nutrition"

次に、ビューに次のような条件を追加します。

<ul>

@For Each item In Model
    Dim currentItem = item

    If (Not String.IsNullOrEmpty(TempData("CurrentPage")) And TempData("CurrentPage") = currentItem.NAV_Element) Then
        @<li><a class="current" href="@Html.DisplayFor(Function(modelItem) currentItem.NAV_Destination)">@Html.DisplayFor(Function(modelItem) currentItem.NAV_Element)</a></li>

    Else
        @<li><a href="@Html.DisplayFor(Function(modelItem) currentItem.NAV_Destination)">@Html.DisplayFor(Function(modelItem) currentItem.NAV_Element)</a></li>
    End If


Next

</ul>
于 2012-09-12T17:41:00.470 に答える
1

ルート値を使用してhrefを生成し、それに基づいて親タブをアクティブに設定することで、過去にこれを達成しました。

これはブートストラップ風味のバージョンです:

 <ul class="nav nav-tabs">
     <li><a href="/somepage">Some page</a></li>
     <li><a href="/someotherpage">Some other Page</a></li>
 </ul>

 <script type="text/javascript">
     $(function(){
          $('a[href="@Url.Action(ViewContext.RouteData.Values)"]').parents("li").addClass("active");
     };

 </script>

于 2012-09-13T11:58:41.787 に答える
0

私はこれに答えるには遅すぎることを知っていますが、ASP MVC を使用していて、コントローラーとアクションを使用してメニュー項目を強調表示しようとしている場合、ここに私にとって完全にうまく機能するソリューションがあります -

<li> <a href='@Url.Action("<action name>", "<controller name>")' class="@(ViewContext.RouteData.Values["Controller"].ToString() + ViewContext.RouteData.Values["Action"].ToString() == "ControllerAction" ? "active" : "" )"> <i class="fa fa-user-plus"></i> <span>Signup</span> </a> </li>

于 2018-01-26T23:41:44.313 に答える