有什么方法可以增加引导3导航栏崩溃的点(即,它崩溃成一个下拉的肖像平板)?
这两个适用于引导2,但不是现在!
如何改变导航栏崩溃阈值使用Twitter引导响应?
更改默认的响应式导航栏断点
有什么方法可以增加引导3导航栏崩溃的点(即,它崩溃成一个下拉的肖像平板)?
这两个适用于引导2,但不是现在!
如何改变导航栏崩溃阈值使用Twitter引导响应?
更改默认的响应式导航栏断点
当前回答
最简单的方法是自定义引导
发现变量:
@grid-float-breakpoint
它被设置为@screen-sm,您可以根据您的需要更改它。 希望能有所帮助!
其他回答
我用CSS的方式安装Bootstrap 3.0.0,因为我不太熟悉LESS。下面是我添加到我的自定义css文件(我在bootstrap.css后加载)的代码,它允许我控制,所以菜单总是像手风琴一样工作。 注意:我将整个导航栏与类边栏一起包装在一个div中,以分离出我想要的行为,这样它就不会影响我网站上的其他导航栏,比如主菜单。根据您的需要进行调整,希望对您有所帮助。
/* Sidebar Menu Fix */
.sidebar .navbar-nav {
margin: 7.5px -15px;
}
.sidebar .navbar-nav > li > a {
padding-top: 10px;
padding-bottom: 10px;
line-height: 20px;
}
.sidebar .navbar-collapse {
max-height: 500px;
}
.sidebar .navbar-nav .open .dropdown-menu {
position: static;
float: none;
width: auto;
margin-top: 0;
background-color: transparent;
border: 0;
box-shadow: none;
}
.sidebar .dropdown-menu > li > a {
color: #777777;
}
.sidebar .navbar-default .navbar-nav .open .dropdown-menu > li > a:hover,
.sidebar .navbar-default .navbar-nav .open .dropdown-menu > li > a:focus {
color: #333333;
background-color: transparent;
}
.sidebar .navbar-default .navbar-nav .open .dropdown-menu > .active > a,
.sidebar .navbar-default .navbar-nav .open .dropdown-menu > .active > a:hover,
.sidebar .navbar-default .navbar-nav .open .dropdown-menu > .active > a:focus {
color: #555555;
background-color: #e7e7e7;
}
.sidebar .navbar-nav {
float: none;
}
.sidebar .navbar-nav > li {
float: none;
}
附加说明:我还对主菜单导航栏的切换进行了更改(因为我网站上的代码用于侧面的“子菜单”)。
我改变了:
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
成:
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse-topmenu">
然后调整:
<div class="navbar-collapse collapse navbar-collapse">
成:
<div class="navbar-collapse collapse navbar-collapse-topmenu">
如果你只有一个导航栏,我猜你不需要担心这个,但它在我的情况下帮助了我。
感谢Seb33300,我得到了这个工作。然而,一个重要的部分似乎被遗漏了。至少在Bootstrap 3.1.1版本中是这样。
我的问题是,导航栏在正确的宽度上相应地折叠,但菜单按钮不起作用。我无法展开和折叠菜单。
这是因为崩溃。In类被.navbar-collapse中的!important重写。也可以通过添加“Collapse .in”来解决。Seb33300的例子完成如下:
@media (max-width: 991px) {
.navbar-header {
float: none;
}
.navbar-toggle {
display: block;
}
.navbar-collapse {
border-top: 1px solid transparent;
box-shadow: inset 0 1px 0 rgba(255,255,255,0.1);
}
.navbar-collapse.collapse {
display: none!important;
}
.navbar-collapse.collapse.in {
display: block!important;
}
.navbar-nav {
float: none!important;
margin: 7.5px -15px;
}
.navbar-nav>li {
float: none;
}
.navbar-nav>li>a {
padding-top: 10px;
padding-bottom: 10px;
}
}
我很关心自定义Bootstrap之后的维护和升级问题。我可以在今天编写定制步骤的文档,并希望三年后升级Bootstrap的人能够找到文档并重新应用这些步骤(在那时可能工作,也可能不工作)。我认为这两种方法都可以,但我更喜欢在代码中保留任何自定义。
不过,我不太明白Seb33300的方法是如何起作用的。当然,Bootstrap 4.0.3不能正常工作。为了使导航栏扩展到1200而不是768,必须重写媒体查询的规则,以防止扩展到768和强制扩展到1200。
我有一个更长的菜单,可以在iPad的纵向模式下自动换行。 下面将菜单一直折叠到1200断点:
@media (min-width: 768px) {
.navbar-header {
float: none; }
.navbar-toggle {
display: block; }
.navbar-fixed-top .navbar-collapse,
.navbar-static-top .navbar-collapse,
.navbar-fixed-bottom .navbar-collapse {
padding-right: 15px;
padding-left: 15px; }
.navbar-collapse.collapse {
display: none !important; }
.navbar-collapse.collapse.in {
display: block!important;
margin-top: 0px; }
}
@media (min-width: 1200px) {
.navbar-header {
float: left; }
.navbar-toggle {
display: none; }
.navbar-fixed-top .navbar-collapse,
.navbar-static-top .navbar-collapse,
.navbar-fixed-bottom .navbar-collapse {
display: block !important; }
}
最简单的方法是自定义引导
发现变量:
@grid-float-breakpoint
它被设置为@screen-sm,您可以根据您的需要更改它。 希望能有所帮助!
这些都是在变量中控制的,不需要在源代码中瞎折腾。使用自举,首先尝试变量,然后重写。然后返回并再次尝试变量;)
我使用bootstrap-sass与rails,但它与默认的LESS是一样的。
FILE: main.css.scss
-------------------
// control the screen sizes
$screen-xs-min: 300px;
$screen-sm-min: 400px;
$screen-md-min: 800px;
$screen-lg-min: 1200px;
// this tells which screen size to use to start breaking on
// will tell navbar when to collapse
$grid-float-breakpoint: $screen-md-min;
// then import your bootstrap
@import "bootstrap";
就是这样!这个变量参考页面非常方便:https://github.com/twbs/bootstrap/blob/master/less/variables.less