首页 > 解决方案 > 使用 Bootstrap 4 在移动设备上定位导航栏图标?

问题描述

我正在尝试在 Bootstrap 4 中配置一个导航栏,以显示其他图标以离开仅在移动设备上显示的汉堡菜单。

我无法让图标内联显示,也无法弄清楚我哪里出错了。

我将类 navbar-nav 添加到列表中, d-lg-none 以隐藏在更大的设备上。引导程序中是否有内置类可以修复这些对齐?我什至无法弄清楚我哪里出错了。

损坏的导航栏

HTML:

        <nav class="navbar navbar-expand-lg">
            <div class="container">
                <a class="navbar-brand" href="#">
                    <img src="assets/images/logo-blue-sm.png" alt="">
                </a>
                <ul class="navbar-nav d-lg-none ml-auto navbar-icons ">
                    <li class="nav-item">
                        <a class="nav-link" href="tel:+1234567890"><i class="fa fa-3x fa-map-marker"></i></a>
                    </li>
                    <li class="nav-item">
                        <a class="nav-link" href="tel:+1234567890"><i class="fa fa-3x fa-comments"></i></a>
                    </li>
                </ul>
                <button class="navbar-toggler ml-auto" type="button" data-toggle="collapse" data-target="#navbarCollapse" aria-controls="navbarCollapse" aria-expanded="false" aria-label="Toggle navigation">
                    <span class="navbar-toggler-icon"> </span>
                </button>
                <div class="collapse navbar-collapse" id="navbarCollapse">
                    <ul class="navbar-nav ml-auto">                 
                        <li class="nav-item dropdown">
                            <a class="nav-link dropdown-toggle" href="#" id="docMenu" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Experience</a>
                            <ul class="dropdown-menu" aria-labelledby="docMenu">
                                <li> <a class="dropdown-item" href="#">Our Story</a> </li>
                            </ul>
                        </li>
                    </ul>
                </div>
                <div class="nav-item border-0 d-none d-lg-inline-block align-self-center">
                    <a href="#" class=" btn btn-sm btn-grad text-white mb-0">Get Started</a>
                </div>
            </div>
        </div>
    </nav>

附加CSS:

.navbar-icons .nav-item{
  border-bottom:none;
  padding:0 5px;
  position:relative;
 }

标签: htmlcsstwitter-bootstrap

解决方案


根据您的布局,您可以使用引导 flex 实用程序类轻松解决该问题阅读更多

只需添加d-flexflex-row类到ul包含项目:

<ul class="navbar-nav d-lg-none ml-auto navbar-icons d-flex flex-row">

这会将uls 显示更改为 flex 并强制 flex 方向为行样式,因此项目将并排显示。

这是一个很好的flexbox指南。尝试了解基础知识并将其与 bootstrap flex 类一起使用。


推荐阅读