【问题标题】:How to keep page active on nav bar whilst using an 'include nav' function使用“包含导航”功能时如何在导航栏上保持页面活动
【发布时间】:2019-09-28 12:38:36
【问题描述】:

我将导航存储在单独的nav.blade.php 文件中,并使用@include('includes.nav') 函数将其调用到每个页面中。这很好用,但我无法突出显示当前页面。

我尝试添加一些其他人在此处描述的代码How to make css a:active work after the click?,但我一直迷路。我是编码新手并且缺少一些东西,我需要一步一步的指南!我认为这也会帮助其他使用引导导航的人。

这是我的nav.blade.php,所有页面都使用@include('includes.nav')调用

<style>
    .navbar {
        padding: 10px;
        font-size: 1.15rem;
        font: "Helvetica Neue";
        /* font-family: "Helvetica Neue", Helvetica, Arial; */
    }

    li {
        float: left;
        text-decoration: none;
        padding: 0px;
        list-style-type: none;
    }
</style>

<!-- Navbar START  -->
<nav class="navbar navbar-expand-sm bg-light navbar-light">
    <a class="navbar-brand" href="/">sitename.com </a>
    <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#collapsibleNavbar">
        <span class="navbar-toggler-icon"></span>
    </button>
    <div class="collapse navbar-collapse" id="collapsibleNavbar">
        <!-- Left Navbar Links -->
        <ul class="navbar-nav mr-auto">
            <li class="nav-item">
                <a class="nav-link" href="welcome">Group Listings</a>
            </li>
            <li class="nav-item">
                <a class="nav-link" href="/about">About</a>
            </li>
            <li class="nav-item">
                <a class="nav-link" href="/contact">Contact</a>
            </li>
        </ul>
        <!-- Right Navbar Links -->
        <ul class="navbar-nav ml-auto">
            @guest
            <li class="nav-item pr-3">
                <a class="nav-link" href="{{ route('login') }}">{{ __('Login') }}</a>
            </li>
            @if (Route::has('register'))
            <li class="nav-item">
                <a class="nav-link" href="{{ route('register') }}">{{ __('Register') }}</a>
            </li>
            @endif
            @else
            <li class="nav-item dropdown">
                <a id="navbarDropdown" class="nav-link dropdown-toggle" href="#" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false" v-pre>
                    {{ Auth::user()->name }} <span class="caret"></span>
                </a>

                <div class="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdown">

                    <!-- <a class="dropdown-item" href="{{ route('profile') }}">My Profile</a> -->
                    <a class="dropdown-item" href="{{ route('home') }}">Dashboard</a>


                    <a class="dropdown-item" href="{{ route('logout') }}" onclick="event.preventDefault();
                        document.getElementById('logout-form').submit();">
                        {{ __('Logout') }}
                    </a>

                    <form id="logout-form" action="{{ route('logout') }}" method="POST" style="display: none;">
                        @csrf
                    </form>
                </div>
            </li>
            @endguest
        </ul>
    </div>
</nav>
<!-- Navbar END  -->

这是我的一个网页示例,它说明了问题

    <head>
    @include('includes.head')
    </head>
    <body>

    <h1>Page content</h1>

    <p>This page calls the navigation from a separate page called head.blade.php. In that page I have a nav with many link, non of which are active. If I make one of them active, then all pages on my website will show that one page as active.</p>

    </body>
    </html>```

【问题讨论】:

    标签: php laravel twitter-bootstrap


    【解决方案1】:
    1. 在导航链接中添加一些额外的代码
    <ul class="navbar-nav mr-auto">
       <li class="nav-item">
           <a class="nav-link @if(Request::is('welcome')) active @endif" href="welcome">Group Listings</a>
      </li>
      <li class="nav-item">
           <a class="nav-link @if(Request::is('about')) active @endif" href="/about">About</a>
      </li>
      <li class="nav-item">
           <a class="nav-link @if(Request::is('contact')) active @endif" href="/contact">Contact</a>
      </li>
    </ul>
    
    1. 把这个放在你所有网页上的&lt;head&gt;&lt;/head&gt;标签之间
     @if(Request::is('route-name')) active @endif"
    

    【讨论】:

    • 谢谢,但是我把这段代码放在哪里呢?我真的很新,发现自己陷入了一堆乱七八糟的代码!
    • 不用担心。你把它放在你想要激活的标签上。我实际上将您的链接复制到了关于页面。我会用更多代码更新我的答案。
    • 问题是,我可以通过在标准引导导航链接中简单地写active 来激活一个选项卡。但是由于我对所有页面都有一个导航,而我的实际网页没有导航,所以没有地方可以向选项卡添加代码!如果我将代码添加到导航上的导航链接,它会同时显示在所有页面上。
    • 我在说明中添加了我的一个网页的示例来说明问题。
    • 使用上面的代码,除非当前路由匹配,否则任何链接都不会处于活动状态,因为它有条件地添加了active 类。你试过了吗?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2022-08-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多