Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I move a div from top to bottom on mobile layouts? [duplicate]

I am using Bootstrap 4, but if it works on version 3, it should work on v4.

I have 2 divs within a column like so:

<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>

Is there a way I can get the divs to swap around on a mobile device? I do not want to use any JavaScript here; I would like to use Bootstrap classes only, if possible.

If it is not possible with Bootstrap, then CSS-only please.

like image 584
Gillardo Avatar asked Oct 21 '15 13:10

Gillardo


People also ask

How do I move a div to the bottom of the page?

Try position:fixed; bottom:0; . This will make your div to stay fixed at the bottom. Hope this helps.

How do I move a div over another?

Basically just make the position of the card block "relative", position the "top" position accordingly, then set the margin to "auto" to center it.


2 Answers

This can be achieved using CSS' flexbox.

  • Add a new selector .col-xs-12 with the following properties:
    • display: flex; tells the children to use the flexbox model
    • flex-direction: column-reverse; will ensure that the children flow from bottom to top (instead of the default left to right)

Run the below Snippet in full screen and resize the window to see the order of the elements change.

@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>

A Bootstrap method

This can also be achieved using Bootstrap:

  • Add the following classes to the container:
    • d-flex to make the container use flexbox
    • flex-column-reverse to order the children in reverse order on small screens
    • flex-sm-column to order the children in normal order on larger screens

<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>
like image 158
Hidden Hobbes Avatar answered Oct 14 '22 09:10

Hidden Hobbes


The following code works for me:

@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>
like image 43
Saif Avatar answered Oct 14 '22 08:10

Saif