【问题标题】:Unable to float elements in Bootstrap navbar无法在 Bootstrap 导航栏中浮动元素
【发布时间】:2017-10-03 23:56:40
【问题描述】:

我在引导导航栏中将元素浮动到右侧时遇到问题,我需要将 float:right 应用于选项 1 和选项 2 元素,并将搜索输入居中,我尝试了 !important 规则但仍然不起作用,当内容已折叠,然后单击导航栏切换按钮,它会从左侧移动一些像素。

编辑:我还需要在按以下顺序折叠时显示导航栏:品牌 - 搜索输入 - 切换按钮。以及搜索输入下切换按钮的内容。

以下是相关代码:

.navbar{
    background-image: cornflowerblue;
}
#mainNav{
    border: 5px solid black;
    margin: 3%;
    background-color: white;
}
body{
    background-color: grey;
}
#navContent{
    background-color: white;
    margin: 3%;
}
#final{
    border: 5px solid black;
    margin: 3%;
    background-color: white;
}
#searchForm{
    margin: auto;
}
#test{
    text-align: center;
    border: 5px solid black;
    float: right;
}
<head>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" integrity="sha384-/Y6pD6FV/Vv2HJnA6t+vslU6fwYXjCFtcEpHbNJ0lyAFsXTsjBbfaDjzALeQsN6M" crossorigin="anonymous">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
</head>
<body>
    <div class="container-fluid">
        <section class="row" id="mainNav">
            <nav class="navbar navbar-expand-xs rounded">
                <a class="navbar-brand" href="#">Brand</a>

                <form class="form-inline" id="searchForm" role="search">
                    <div class="input-group">
                        <input class="form-control" type="text" placeholder="Search">
                        <div class="input-group-btn">
                            <button class="btn btn-secondary" type="button"><i class="fa fa-search"></i></button>
                        </div>
                    </div>
                </form>

                <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navToggler" aria-controls="navToggler" aria-expanded="false" aria-label="Toggle navigation">
                    <i class="fa fa-bars"></i>
                </button>
                <div id="test">
                    <div class="collapse navbar-collapse" id="navToggler">
                        <ul class="navbar-nav">
                            <li class="nav-item"><a class="nav-link" href="#">Option 1</a></li>
                            <li class="nav-item"><a class="nav-link" href="#">Option 2</a></li>
                        </ul>
                    </div>
                </div>
            </nav>
        </section>
        </div>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.11.0/umd/popper.min.js" integrity="sha384-b/U6ypiBEHpOf/4+1nzFpr53nxSS+GLCkfwBdFNTxtclqqenISfwAzpKaMNFNmj4" crossorigin="anonymous"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js" integrity="sha384-h0AbiXch4ZDo7tp9hKZ4TsHbi047NrKGLO3SEJAg45jXxnGIfYzk4Si90RDIqNm1" crossorigin="anonymous"></script>
    <script src="js/index.js"></script>
        </body>

【问题讨论】:

    标签: css html twitter-bootstrap bootstrap-4


    【解决方案1】:

    只需在下面添加&lt;div class="col-md-12"&gt;&lt;/div&gt; 即可使用该部分

    .navbar{
        background-image: cornflowerblue;
    }
    #mainNav{
        border: 5px solid black;
        margin: 3%;
        background-color: white;
    }
    body{
        background-color: grey;
    }
    #navContent{
        background-color: white;
        margin: 3%;
    }
    #final{
        border: 5px solid black;
        margin: 3%;
        background-color: white;
    }
    #searchForm{
        margin: auto;
    }
    #test{
        text-align: center;
        border: 5px solid black;
        float: right;
    }
    <head>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" integrity="sha384-/Y6pD6FV/Vv2HJnA6t+vslU6fwYXjCFtcEpHbNJ0lyAFsXTsjBbfaDjzALeQsN6M" crossorigin="anonymous">
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
    </head>
    <body>
        <div class="container-fluid">
            <section class="row" id="mainNav">
            <div class="col-md-12">
                <nav class="navbar rounded">
                    <a class="navbar-brand" href="#">Brand</a>
    
                    <form class="form-inline" id="searchForm" role="search">
                        <div class="input-group">
                            <input class="form-control" type="text" placeholder="Search">
                            <div class="input-group-btn">
                                <button class="btn btn-secondary" type="button"><i class="fa fa-search"></i></button>
                            </div>
                        </div>
                    </form>
    
                    <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navToggler" aria-controls="navToggler" aria-expanded="false" aria-label="Toggle navigation">
                        <i class="fa fa-bars"></i>
                    </button>
                    <div id="test">
                        <div class="collapse navbar-collapse" id="navToggler">
                            <ul class="nav navbar-nav">
                                <li class="nav-item"><a class="nav-link" href="#">Option 1</a></li>
                                <li class="nav-item"><a class="nav-link" href="#">Option 2</a></li>
                            </ul>
                        </div>
                    </div>
                </nav>
                </div>
            </section>
            </div>
            <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.11.0/umd/popper.min.js" integrity="sha384-b/U6ypiBEHpOf/4+1nzFpr53nxSS+GLCkfwBdFNTxtclqqenISfwAzpKaMNFNmj4" crossorigin="anonymous"></script>
        <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js" integrity="sha384-h0AbiXch4ZDo7tp9hKZ4TsHbi047NrKGLO3SEJAg45jXxnGIfYzk4Si90RDIqNm1" crossorigin="anonymous"></script>
        <script src="js/index.js"></script>
            </body>

    【讨论】:

    • 你想总是显示切换按钮,任何宽度
    • 不,当导航栏折叠时,我想在一行中显示品牌 - 搜索 - 切换按钮,以及搜索输入下的切换按钮内容
    • 在堆栈溢出中,sn-p 已经崩溃,但我的意思是说宽度更小
    • 检查我更新的答案,并从您的代码中删除类 navbar-expand-xs。现在可以使用了
    【解决方案2】:

    如果你想要 Bootstrap 4 中的超级菜单(例如 Boostrap 3 的 yamm),我使用 flexbox 取得了成功:

    <!-- adapted from bs-repo basic navbar example code -->
    <nav id="navbar" class="navbar navbar-expand-lg navbar-light bg-light">
      <a class="navbar-brand" href="#">Navbar</a>
      <button class="navbar-toggler" type="button" data-toggle="collapse"
              data-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 mr-auto">
          <li class="nav-item active">
            <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>
          </li>
          <li class="nav-item">
            <a class="nav-link" href="#">Link</a>
          </li>
          <li class="nav-item dropdown">
            <a class="nav-link dropdown-toggle" href="http://example.com"
               id="navbarDropdownMenuLink" data-toggle="dropdown"
               aria-haspopup="true" aria-expanded="false">Dropdown link</a>
            <div class="dropdown-menu"
                 aria-labelledby="navbarDropdownMenuLink">
              <ul class="d-md-inline-flex flex-md-row">
                <li class="dropdown-item">
                  <ul class="d-md-inline-flex flex-md-column">
                    <li class="dropdown-item"><a href="#">Action</a></li>
                    <li class="dropdown-item"><a href="#">Another action</a></li>
                    <li class="dropdown-item"><a href="#">Something else here</a></li>
                  </ul>
                </li>
                <li class="dropdown-item">
                  ...
                </li>
                <li class="dropdown-item">
                  ...
                </li>
              </ul>
            </div>
          </li>
        </ul>
        <form class="form-inline my-2 my-lg-0">
          <input class="form-control mr-sm-2" type="text"
                 placeholder="Search" aria-label="Search">
          <button class="btn btn-outline-success my-2 my-sm-0"
                  type="submit">Search</button>
        </form>
      </div>
    </nav>
    

    【讨论】:

      【解决方案3】:

      使用 Bootstrap 4 集成的 Flex 系统。我稍微清理了代码并添加了魔法 ml-auto (margin-left:auto)。 试试看吧。

      .navbar{
          background-image: cornflowerblue;
      }
      #mainNav{
          border: 5px solid black;
          margin: 3%;
          background-color: white;
      }
      body{
          background-color: grey;
      }
      #navContent{
          background-color: white;
          margin: 3%;
      }
      #final{
          border: 5px solid black;
          margin: 3%;
          background-color: white;
      }
      #searchForm{
          margin: auto;
      }
      
      <html>
      <head>
          <title></title>
      </head>
      <body>
          <link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/css/bootstrap.min.css" rel="stylesheet">
          <link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
          <div class="container-fluid">
              <nav class="navbar navbar-expand-lg rounded" id="mainNav">
                  <a class="navbar-brand" href="#">Brand</a>
                  <form class="form-inline" id="searchForm" name="searchForm" role="search">
                      <div class="input-group">
                          <input class="form-control" placeholder="Search" type="text">
                          <div class="input-group-btn">
                              <button class="btn btn-secondary" type="button"><i class="fa fa-search"></i></button>
                          </div>
                      </div>
                  </form>
                  <button aria-controls="navToggler" aria-expanded="false" aria-label="Toggle navigation" class="navbar-toggler" data-target="#navToggler" data-toggle="collapse" type="button"><i class="fa fa-bars"></i></button>
                  <div class="collapse navbar-collapse ml-auto" id="navToggler">
                      <ul class="navbar-nav">
                          <li class="nav-item">
                              <a class="nav-link" href="#">Option 1</a>
                          </li>
                          <li class="nav-item">
                              <a class="nav-link" href="#">Option 2</a>
                          </li>
                      </ul>
                  </div>
              </nav>
          </div>
          <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js">
          </script> 
          <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.11.0/umd/popper.min.js">
          </script> 
          <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta/js/bootstrap.min.js">
          </script>
      </body>
      </html>
      

      【讨论】:

        猜你喜欢
        • 2019-03-19
        • 2016-06-05
        • 1970-01-01
        • 1970-01-01
        • 2016-02-25
        • 1970-01-01
        • 2014-02-27
        • 1970-01-01
        • 2021-01-29
        相关资源
        最近更新 更多