linkedin github twitter

Teach CSS - Card Flip

Ever wonder how to create a card flip in CSS? Wonder no longer. In this example, I'll show how to achieve it with some CSS, and just the tiniest bit of JavaScript (which only toggles a CSS class!)

Note, not all browsers support this trick, so be carefull!

Example

Lorem ipsum dolor sit amet, consectetur adipiscing elit. Donec vehicula enim quis lorem semper, non vulputate tortor auctor. In hac habitasse platea dictumst. Donec ac lorem ante.

Vestibulum elementum quam quis sem scelerisque, nec posuere leo sollicitudin. Quisque sed quam id ligula semper pellentesque cursus eu lectus. Sed congue orci quis nisi pulvinar, eu varius risus lacinia.

Donec sit amet mi rhoncus, tincidunt nulla vitae, pellentesque lectus.

Walkthrough

First we want our card to have a front and back side, so here's the HTML we'll want to build it.

<div class="card">
      <div class="card__front">...content...</div>
      <div class="card__back">...content...</div>
    </div>

Now for the CSS part. We want both sides of the card to be the full width and height of the card, and we want them positioned on top of each other. So for both, we'll absolutely position them, and set top, left, right, and bottom to 0 (also, make sure you give your card a width and height!)

Now they are sitting on top of each other, and it's a hot mess. Content sitting on content. How do we deal with that? Two steps: we'll flip the card's back side component over, and hide the backface of it.

.card__front,
    .card__back {
      backface-visibility: hidden;
    }

    .card__back {
      transform: rotateY(180deg);
    }

The `transform` rule will flip the card over, and that `backface-visibility` rule says that backface of the element isn't visible; i.e. when the element is flipped over and your looking at the back of the element, should you be able to see it or not? In our case, we don't want to see it.

Sweet, there's our card! But at the moment we can't flip it over. Let's add that ability. First, we add an `onclick` listener to the card, which will just toggle if the card has the class `card--flipped`. But how does the CSS need to change to accomadate it?

.card:not(.card--flipped) .card__back {
      transform: rotateY(180deg);
    }

    .card.card--flipped .card__front {
      transform: rotateY(180deg);
    }

That's short and easy right? Any card that's not flipped should have it's card back component flipped over (so that we see the front). Any card that IS flipped over should instead have it's front side component flipped over (so that we see the back). Then all we need to do is add a transition for the transform, and there it is! Our finished card flip!