5

我正在使用引导程序 3.0.0。

在使用默认导航栏示例和一些自定义 CSS 时,我发现搜索表单文本框在 chrome 上占据全宽,因此我的导航栏被分成三行。它在 Firefox 和 IE 上运行良好。

问题是,Firefox 中的计算宽度为 236 像素,但在 chrome 中为 1110 像素。Firefox 和 chrome 截图都附在最后。屏幕截图后以及JSFiddle给出了代码,但在那里看不到输出。它仅供参考。

它是 chrome 中的一个已知错误,还是更可能是我犯了一些错误。如果是的话,有人可以弄清楚我犯了什么错误吗?

铬截图 火狐截图

自定义 CSS

@import url(http://fonts.googleapis.com/css?family=Spirax|Oleo+Script+Swash+Caps&text=FlipKhan);
body{background: url("../images/bg.gif") scroll center top #C0C0C0;}
.navbar-top {margin-bottom: 0; min-height: 35px; height:50px;}
.navbar-top div.container{height:45px;}
.navbar-top div.container div.navbar-header{height:45px;}
.navbar-top a.navbar-brand {padding: 10px;}
.navbar-top div.container div.collapse{height:45px;}
.navbar-top .navbar-brand {font-family: 'Oleo Script Swash Caps', cursive; font-size: 35px; color: #FFF;}
.navbar-inverse {
  background: none !important; 
  border: 0 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}
.navbar-inverse .nav .active > a {
  background: 0 !important; 
  color: #333 !important;
  box-shadow: none !important;
  -webkit-box-shadow: none !important;
}
.navbar-inverse .nav > li > a {
  color: #333 !important;
  text-shadow: none !important;
}
.navbar-inverse .nav > li > a:hover {
  color: #333 !important;
}

HTML(仅用于导航栏)

<header>
  <nav class="navbar navbar-top navbar-default navbar-inverse" role="navigation">
    <div class="container">
      <!-- Brand and toggle get grouped for better mobile display -->
      <div class="navbar-header">
        <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-ex1-collapse">
          <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="index.html">FlipKhan</a>
      </div>
      <!-- Collect the nav links, forms, and other content for toggling -->
      <div class="collapse navbar-collapse navbar-ex1-collapse">
        <form class="navbar-form navbar-left navbar-search" role="search">
          <div class="col-lg-12">
            <div class="input-group">
              <input type="text" class="form-control input-sm">
              <span class="input-group-btn">
                <button class="btn btn-info btn-sm" type="submit"><span class="glyphicon glyphicon-search"></button>
              </span>
            </div><!-- /input-group -->
          </div><!-- /.col-lg-6 -->
        </form>
        <ul class="nav navbar-nav navbar-right">
          <li><a href="#">Login</a></li>
          <li><a href="#">Register</a></li>
        </ul>
      </div><!-- /.navbar-collapse -->
    </div>
  </nav>
</header>

编辑:

在 chrome 中的 CSS 修复问题中添加以下行

.navbar-search{max-width: 250px;}

但是我认为这是黑客行为。没有更好的方法来解决这个问题吗?

4

2 回答 2

2

I had the same problem on Chrome. I resolved it adding display:table on form element.

Better solution is to add this css:

@media (min-width: 767px) {
  .navbar-form.navbar-left{
    display:table;
  }
}

I also removed your <div class="col-lg-12"> (with it, it doesn't work):

<form class="navbar-form navbar-left navbar-search" role="search">        
        <div class="input-group">
          <input type="text" class="form-control input-sm">
          <span class="input-group-btn">
            <button class="btn btn-info btn-sm" type="submit"><span class="glyphicon glyphicon-search"/></button>
          </span>
        </div><!-- /input-group -->
</form>
于 2014-08-24T23:39:23.640 回答
2

你也可以在其他浏览器中测试吗?我认为 chrome 渲染可能是正确的。但你是对的,输入在 chrome 和 firefox 中呈现不同。

您可以将问题简化为:

<div style="float:left;">
<div class="input-group">
              <input type="text" class="form-control input-sm">
              <span class="input-group-btn">
              <button class="btn btn-info btn-sm" type="submit"><span class="glyphicon glyphicon-search"></span></button>
              </span>
</div>
</div>

请注意,需要向左浮动来显示差异(您的向左浮动来自 navbar-left 类)。

以上可以“翻译”为:

<div style="float:left;">
<div style="height:10px;background-color:red;" style="width:100%;">
<span style="display:table-cell;position:relative;width:1%;">txt</span>
</div>
</div>

在没有 Boostrap 的 CSS 的情况下,上述内容在 chrome 和 Firefox 中呈现不同。我不知道 Bootstrap CSS 是错误的还是其中一个浏览器现在是错误的。另见:https ://github.com/twbs/bootstrap/issues/10645

于 2013-09-14T22:25:34.090 回答