13

我正在使用 Bootstrap 4,但如果它适用于版本 3,它应该适用于 v4。

我在一列中有 2 个 div,如下所示:

<div class="row">
    <div class="col-xs-12">
        <div>TOP ON DESKTOP, BOTTOM ON MOBILE</div>
        <div>BOTTOM ON DESKTOP, TOP ON MOBILE</div>
    </div>
</div>

有没有办法让 div 在移动设备上交换?我不想在这里使用任何 JavaScript;如果可能的话,我只想使用 Bootstrap 类。

如果 Bootstrap 无法实现,请仅使用 CSS。

4

3 回答 3

36

这可以使用 CSS' 来实现flexbox

  • 添加.col-xs-12具有以下属性的新选择器:
    • display: flex;告诉孩子们使用flexbox模型
    • flex-direction: column-reverse;将确保孩子从下到上流动(而不是默认的从左到右)

全屏运行以下代码段并调整窗口大小以查看元素顺序的变化。

@media only screen and (max-width: 960px) {
  .col-xs-12 {
    display: flex;
    flex-direction: column-reverse;
  }
}
<div class="row">
  <div class="col-xs-12">
    <div>TOP ON DESKTOP, BOTTOM ON MOBILE</div>
    <div>BOTTOM ON DESKTOP, TOP ON MOBILE</div>
  </div>
</div>

引导方法

这也可以使用 Bootstrap 来实现:

  • 将以下类添加到容器中:
    • d-flex使容器使用 flexbox
    • flex-column-reverse在小屏幕上以相反的顺序对孩子进行排序
    • flex-sm-column在大屏幕上按正常顺序对孩子进行排序

<link href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet" />
<div class="row">
  <div class="col-xs-12 d-flex flex-column-reverse flex-sm-column">
    <div>TOP ON DESKTOP, BOTTOM ON MOBILE</div>
    <div>BOTTOM ON DESKTOP, TOP ON MOBILE</div>
  </div>
</div>

于 2015-10-21T13:47:26.060 回答
4

以下代码适用于我:

@media only screen and (max-width: 768px) {
  .xs-column-reverse {
    display: flex;
    flex-direction: column-reverse;
  }
}
<div class="row">
  <div class="col-xs-12 xs-column-reverse">
    <div>TOP ON DESKTOP, BOTTOM ON MOBILE</div>
    <div>BOTTOM ON DESKTOP, TOP ON MOBILE</div>
  </div>
</div>
于 2018-11-09T13:48:44.697 回答
0
.col-xs-12 { height: 200px; position:relative; }
.col-xs-12 div { position:absolute; top:0; left: 0; width:100%; }
.col-xs-12 div:last-child { top: auto; bottom: 0; }

@media (max-width: 480px) {
    .col-xs-12 div { top:auto; bottom:0; }
    .col-xs-12 div:last-child { top: 0; bottom: auto; }
}
于 2015-10-21T13:24:38.913 回答