我正在制作一个顶部固定导航条的响应式布局。下面有两列,一列是边栏(3),一列是内容(9),在桌面上看起来是这样的

导航条 [3] [9]

当我调整大小移动导航栏被压缩和隐藏,然后边栏堆叠在内容的顶部,就像这样:

navbar [3] [9]

我想在顶部的主要内容,所以我需要改变移动的顺序为:

navbar [9] [3]

我发现这篇文章涵盖了同样的观点,但公认的答案已被编辑,说解决方案不适用于当前版本的Bootstrap。

如何在移动设备上重新排序这些列?或者,我如何能得到边栏列表组到我的扩展导航栏?

这是我的代码:

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <!-- Latest compiled and minified CSS --> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous"> <!-- Optional theme --> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap-theme.min.css" integrity="sha384-rHyoN1iRsVXV4nD0JutlnGaslCJuC7uwjduW9SVrLvRYooPp2bWYgmgJQIXwl/Sp" crossorigin="anonymous"> <!-- Latest compiled and minified JavaScript --> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script> <div class="navbar navbar-inverse navbar-static-top"> <div class="container"> <a href="#" class="navbar-brand">Brand Title</a> <button class="navbar-toggle" data-toggle="collapse" data-target=".navHeaderCollapse"> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> <div class="collapse navbar-collapse navHeaderCollapse"> <ul class="nav navbar-nav navbar-right"><!--original navbar--> <li class="active"><a href="#">Home</a></li> <li><a href="#">FAQ</a></li> </ul> </div> </div> </div><!--End Navbar Div--> <div class="container"> <div class="row"> <div class="col-lg-3"> <div class="list-group"> <a href="#" class="list-group-item"> <h4 class="list-group-item-heading">Lorem ipsum</h4> <p class="list-group-item-text">Lorem Ipsum is simply dummy text.</p></a> </div> </div><!--end sidebar--> <div class="col-lg-9"> <div class="panel panel-default"> <div class="panel-body"> <div class="page-header"> Main Content </div> </div> </div><!--end main content area-->


当前回答

这很容易用jQuery使用insertAfter()或insertBefore():

<div class="left">content</div>
<div class="right">sidebar</div>

< >脚本 $(“铃声”).insertBefore(左); > < /脚本

如果你想为移动设备设置一个条件,你可以这样做:

< >脚本 var $iW = $(window).innerWidth(); if ($iW < 992){ $(“铃声”).insertBefore(“.left”); 其他}{ $(“铃声”).insertAfter(“.left”); } > < /脚本

例子 https://jsfiddle.net/w9n27k23/

其他回答

2017年10月

我想添加另一个Bootstrap 4解决方案。一个对我有用的方法。

CSS的“Order”属性,结合媒体查询,可以用来重新排序列时,他们被堆叠在较小的屏幕。

就像这样:

@media only screen and (max-width: 768px) {
    #first {
        order: 2;
    }
    #second {
        order: 4;
    }
    #third {
        order: 1;
    }
    #fourth {
        order: 3;
    }
}

代码依赖链接:https://codepen.io/preston206/pen/EwrXqm

调整屏幕大小,您将看到列以不同的顺序堆叠。

我会把这个和原来的问题联系起来。使用CSS,导航栏、侧边栏和内容可以被定位,然后对媒体查询中应用的属性进行排序。

这很容易用jQuery使用insertAfter()或insertBefore():

<div class="left">content</div>
<div class="right">sidebar</div>

< >脚本 $(“铃声”).insertBefore(左); > < /脚本

如果你想为移动设备设置一个条件,你可以这样做:

< >脚本 var $iW = $(window).innerWidth(); if ($iW < 992){ $(“铃声”).insertBefore(“.left”); 其他}{ $(“铃声”).insertAfter(“.left”); } > < /脚本

例子 https://jsfiddle.net/w9n27k23/

更新2018

对于基于Bootstrap 3的原始问题,解决方案是使用推拉。

在Bootstrap 4,现在可以改变顺序,即使当列是全宽垂直堆叠,感谢Bootstrap 4 flexbox。OFC中,push - pull方法仍然可以工作,但是现在在Bootstrap 4中有其他方法来改变列的顺序,使全宽列重新排序成为可能。

方法1 -对xs屏幕使用flex-column-reverse:

<div class="row flex-column-reverse flex-md-row">
    <div class="col-md-3">
        sidebar
    </div>
    <div class="col-md-9">
        main
    </div>
</div>

方法2 - xs屏幕使用顺序优先:

<div class="row">
    <div class="col-md-3">
        sidebar
    </div>
    <div class="col-md-9 order-first order-md-last">
        main
    </div>
</div>

引导4(alpha 6): http://www.codeply.com/go/bBMOsvtJhD 引导4.1:https://www.codeply.com/go/e0v77yGtcr


原来的3。x回答

对于基于Bootstrap 3的原始问题,解决方案是对较大的宽度使用push-pull,然后列将显示它们在较小(xs)宽度上的自然顺序。(A-B转B-A)。

<div class="container">
    <div class="row">
        <div class="col-md-9 col-md-push-3">
            main
        </div>
        <div class="col-md-3 col-md-pull-9">
            sidebar
        </div>
    </div>
</div>

引导3:http://www.codeply.com/go/wgzJXs3gel

@emre说,“你不能在小屏幕上改变列的顺序,但你可以在大屏幕上这样做”。但是,在Bootstrap 3中应该澄清:“您不能更改全宽“堆叠”列的顺序..”。

引导3答案

这里的答案只适用于2个单元格,但一旦这些列中有更多的单元格,就会导致稍微复杂一些。我认为我已经找到了一个适用于多列任意数量单元格的通用解。

目标

在移动设备上获得标签的垂直序列,以平板电脑/台式机上的设计要求的任何顺序排列自己。在这个具体的例子中,一个标记必须比正常情况下更早进入flow,而另一个必须比正常情况下更晚进入flow。

移动

[1 headline]
[2 image]
[3 qty]
[4 caption]
[5 desc]

平板电脑+。

[2 image  ][1 headline]
[         ][3 qty     ]
[         ][5 desc    ]
[4 caption][          ]
[         ][          ]

因此,在平板电脑+上,标题需要右移,从技术上讲,desc也是如此——它位于移动设备上的标题标签之上。你马上就会看到4个标题也有麻烦了。

让我们假设每个单元格的高度不同,并且需要与下一个单元格从上到下保持齐平(排除了像桌子这样的弱技巧)。

与所有的Bootstrap Grid问题一样,第一步是要意识到HTML必须在页面上按移动顺序排列,1 2 3 4 5。然后,确定如何让平板电脑/台式机以这种方式重新排序-理想情况下不需要Javascript。

要让1个标题和3个数量坐在右边而不是左边,解决方案是简单地将它们都设置为右拉。这应用了CSS float: right,这意味着它们找到了第一个适合右边的开放空间。您可以认为浏览器的CSS处理器是按照以下顺序工作的:1适合右上角。2是下一个,是常规的(float: left),所以它会到左上角。然后是3,也就是浮点数,所以它从1下面跳过去。

但这个解决方案还不足以满足4个标题;因为右边的两个单元格太短了,左边的两个图像往往比它们加起来还要长。Bootstrap Grid是一个光荣的浮动hack,意味着4标题是浮动:左。左边有2张图片占据了这么大的空间,4个标题试图进入下一个可用的空间——通常是右列,而不是我们想要的左边。

这里的解决方案(以及更普遍的任何类似的问题)是添加一个黑客标签,隐藏在移动设备上,存在于平板电脑+上,将标题推出,然后被负边缘覆盖-就像这样:

[2 image  ][1 headline]
[         ][3 qty     ]
[         ][4 hack    ]
[5 caption][6 desc ^^^]
[         ][          ]

http://jsfiddle.net/b9chris/52VtD/16633/

HTML:

<div id=headline class="col-xs-12 col-sm-6 pull-right">Product Headline</div>
<div id=image class="col-xs-12 col-sm-6">Product Image</div>
<div id=qty class="col-xs-12 col-sm-6 pull-right">Qty, Add to cart</div>
<div id=hack class="hidden-xs col-sm-6">Hack</div>
<div id=caption class="col-xs-12 col-sm-6">Product image caption</div>
<div id=desc class="col-xs-12 col-sm-6 pull-right">Product description</div>

CSS:

#hack { height: 50px; }

@media (min-width: @screen-sm) {
    #desc { margin-top: -50px; }
}

所以,这里的通用解决方案是添加可以在移动设备上消失的黑客标签。在平板电脑+ hack标签允许显示的标签出现在更早或更晚的流程中,然后向上或向下拉,以掩盖这些hack标签。

注意:为了在链接的jsfiddle中实现简单的示例,我使用了固定的高度,但是我正在处理的实际站点内容在所有5个标记中的高度是不同的。它在标签高度上有较大的差异,特别是图像和描述。

注2:根据你的布局,你可能在tablet+(或更大的分辨率)上有足够一致的列顺序,你可以避免使用hack标签,而是使用margin-bottom,如下所示:

注意3:这使用Bootstrap 3。Bootstrap 4使用了不同的网格集,不能用于这些示例。

http://jsfiddle.net/b9chris/52VtD/16632/

在Bootstrap 4中,如果你想做这样的事情:

    Mobile  |   Desktop
-----------------------------
    A       |       A
    C       |   B       C
    B       |       D
    D       |

你需要颠倒B和C的顺序,然后应用order-{breakpoint}-first到B,并应用两个不同的设置,一个将使它们共享相同的cols,另一个将使它们采用12个cols的全宽度:

较小的屏幕:12 cols到B和12 cols到C 更大的屏幕:12 cols (B + C = 12)

像这样

<div class='row no-gutters'>
    <div class='col-12'>
        A
    </div>
    <div class='col-12'>
        <div class='row no-gutters'>
            <div class='col-12 col-md-6'>
                C
            </div>
            <div class='col-12 col-md-6 order-md-first'>
                B
            </div>
        </div>
    </div>
    <div class='col-12'>
        D
    </div>
</div>

演示:https://codepen.io/anon/pen/wXLGKa