Bootstrap导航栏未在IE11上正确居中

时间:2017-01-28 06:27:11

标签: css twitter-bootstrap internet-explorer-11 navbar

我正在制作一个非常简单的自举导航栏原型,我想要的最大宽度为600px,以屏幕为中心并固定在顶部。

这是html代码:



.navbar {
  max-width: 600px;
  margin: 0 auto;
}

<link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<nav class="navbar navbar-default navbar-fixed-top">
  <div class="container-fluid">
    <!-- Brand and toggle get grouped for better mobile display -->
    <div class="navbar-header">
      <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
        <span class="sr-only">Toggle navigation</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="#">Brand</a>
    </div>

    <!-- Collect the nav links, forms, and other content for toggling -->
    <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
      <ul class="nav navbar-nav navbar-right">
        <li><a href="#">MyLink</a>
        </li>
      </ul>
    </div>
    <!-- /.navbar-collapse -->
  </div>
  <!-- /.container-fluid -->
</nav>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
&#13;
&#13;
&#13;

适用于Chrome和Firefox。但是在IE11上,导航栏没有居中,而是粘在屏幕的左侧(正确应用600px的宽度)。

在查看检查屏幕后,我可以将问题范围缩小到“固定”状态。应用于.navbar-fixed-bottom和.navbar-fixed-top类的属性(bootstrap.min.css(5))。 当我取消选择&#39;位置:固定&#39;在IE检查窗口中的属性,然后位置变为静态&#39;并且导航栏居中。请注意&#39;位置:静态&#39;不是我不想要的,因为那时导航栏不再固定在屏幕上了。

有谁知道为什么IE不能正确地将导航栏置于中心位置:固定&#39;应用于nav元素的属性,而它适用于其他浏览器? 有没有现成的解决方法?

如果我在这里做得不对,请告诉我。

2 个答案:

答案 0 :(得分:1)

这是由navbar-fixed-top课程引起的。只需申请width: 100%就可以了。

.navbar.navbar-default {
  max-width: 600px;
  margin: 0 auto;
  width: 100%;
}
<link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">

<nav class="navbar navbar-default navbar-fixed-top">
  <div class="container-fluid">
    <!-- Brand and toggle get grouped for better mobile display -->
    <div class="navbar-header">
      <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
        <span class="sr-only">Toggle navigation</span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
        <span class="icon-bar"></span>
      </button>
      <a class="navbar-brand" href="#">Brand</a>
    </div>

    <!-- Collect the nav links, forms, and other content for toggling -->
    <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
      <ul class="nav navbar-nav navbar-right">
        <li><a href="#">MyLink</a>
        </li>
      </ul>
    </div>
    <!-- /.navbar-collapse -->
  </div>
  <!-- /.container-fluid -->
</nav>

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.2.2/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

答案 1 :(得分:0)

由于max-width而无法正常工作。试试这个:

.navbar {
 width: 600px;
 margin: 0 auto;
}