【问题标题】:how to prevent bootstrap navbar split into few lines when collapsed折叠时如何防止引导导航栏分成几行
【发布时间】:2021-07-20 21:06:45
【问题描述】:

我整天都在寻找它,但找不到解决方案,所以我希望在 2 分钟内有人会发布确切问题的已回答链接时,我不会看起来像个白痴。

我正在尝试创建一个类似steamdb 的导航栏 导航栏折叠后搜索框保留的位置,只是缩小了大小。

但是我遇到了一个问题,如果我将导航栏设置为<nav class="navbar-expand-lg" </nav>,那么当它折叠时它会分成 3 行,一行用于品牌,一行用于搜索,另一行用于切换下拉菜单。

如果我删除“-lg”,则它不会拆分,但也不会更改要切换的项目。

<nav class="navbar navbar-expand-lg navbar-light bg-light">
    <div class="container">
      <a class="navbar-brand" href="/">My Company Name</a>
      <form class="d-flex w-100 d-inline-block">
        <div class="input-group">
          <input class="form-control no-border" type="text" placeholder="search for game..." id="example-search-input">
            <span class="input-group-append">
              <button class="btn rounded-pill" type="button">
              <i class="bi bi-search"></i>
              </button>
            </span>
        </div>
      </form>
      <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent"
        aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
        <span class="navbar-toggler-icon"></span>
      </button>

      <div class="collapse navbar-collapse" id="navbarSupportedContent">
        <ul class="navbar-nav ms-auto mb-2 mb-lg-0">
          <li class="nav-item">
            <a class="nav-link active" aria-current="page" href="/">Home</a>
          </li>
          <li class="nav-item dropdown">
            <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown"
              aria-expanded="false">
              content
            </a>
            <ul class="dropdown-menu" aria-labelledby="navbarDropdown">
              <li><a class="dropdown-item" href="/test1">test1</a></li>
              <li><a class="dropdown-item" href="/test2">test2</a></li>
              <li><a class="dropdown-item" href="/test3">test3</a></li>
            </ul>
          </li>
          <li class="nav-item">
            <a class="nav-link" href="#">Donate</a>
          </li>
        </ul>
      </div>
    </div>
  </nav>

https://www.codeply.com/p/uaWJpGVRED

请帮忙,我整天都被困在这个问题上

【问题讨论】:

    标签: css twitter-bootstrap navbar bootstrap-5


    【解决方案1】:

    您需要在容器内使用 2 个内部 div。把它们都做成w-100,和第一个d-flex,这样品牌和表格布局就横向了……

      <nav class="navbar navbar-expand-lg navbar-light bg-light">
          <div class="container">
              <div class="d-flex w-100">
                  <a class="navbar-brand" href="/">My Company Name</a>
                  <form class="d-flex w-100 d-inline-block">
                      <div class="input-group">
                          <input class="form-control no-border" type="text" placeholder="search for game..." id="example-search-input">
                          <span class="input-group-append">
                              <button class="btn rounded-pill" type="button">
                                  <i class="bi bi-search"></i>
                              </button>
                          </span>
                      </div>
                  </form>
                  <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
                      <span class="navbar-toggler-icon"></span>
                  </button>
              </div>
              <div class="collapse navbar-collapse w-100" id="navbarSupportedContent">
                  <ul class="navbar-nav ms-auto mb-2 mb-lg-0">
                      <li class="nav-item">
                          <a class="nav-link active" aria-current="page" href="/">Home</a>
                      </li>
                      <li class="nav-item dropdown">
                          <a class="nav-link dropdown-toggle" href="#" id="navbarDropdown" role="button" data-bs-toggle="dropdown" aria-expanded="false"> content </a>
                          <ul class="dropdown-menu" aria-labelledby="navbarDropdown">
                              <li><a class="dropdown-item" href="/test1">test1</a></li>
                              <li><a class="dropdown-item" href="/test2">something</a></li>
                              <li><a class="dropdown-item" href="/test3">bla bla</a></li>
                          </ul>
                      </li>
                      <li class="nav-item">
                          <a class="nav-link" href="#">Donate</a>
                      </li>
                  </ul>
              </div>
          </div>
      </nav>
    

    Demo

    【讨论】:

    • 非常感谢,让我看看我是否明白这一点,因为这让我回到文档中查看 d-flex 和 w-* 的作用。通过改变这一点。以及 d-* 在引导程序中的一般工作方式。所以我在那里所做的是将折叠的工具栏更改为 flex,这意味着默认为行。因此,在该视图中,它不能转到 2 行。通过将搜索框设置为 w-100,我强制它占用所有空间。第二个改为 w-100 只是为了防止它进入第一个。我猜对了吗?
    • 其实你不需要w-100。请接受答案,以便其他人知道问题已解决。
    • 是的,我后来意识到 w-100 会导致问题。无论如何,谢谢
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-10-19
    • 1970-01-01
    相关资源
    最近更新 更多