Build a social profile card component using FlexBox

In this article we will demonstrate a social profile card component built and designed using FlexBox. The techniques look simple but it helps to improve our FlexBox knowledge to build more complex components.

I got the idea from freshman and tweaked it for our needs. This is the pen for what we are going to explain:

Social profile card markup

The whole idea is to design a social profile card that can be of any social media. The very first thing is to design the HTML. These are the main elements of the markup structure:

<div class="photo">
  <div class="top">
   // the top links go here
  <div class="middle"><h3>Coding is my passion!</h3></div>
  <div class="bottom">
   // the image and link in the bottom go here

As we see the div with .photo class is the main container. So we design its layout like below:

  display: flex;
  flex-direction: column;
  justify-content: space-between;

Firstly we change the direction of the flex container to column so that the .top and .middle and  .bottom divs which are the immediate children of .photo div could be stacked on top of each other. Meaning we need to design them each in the location that their name suggest.

Also we justify the content with space-between so that they have space in between them only.

The top bar

For the top bar we want the buttons to have even space in between them and look centred in the middle so the user can see them both at once:

.top {
  display: flex;
  justify-content: space-around;

Therefor we need to justify the content using space-around which makes sure buttons are positioned with space before, between, and after the lines.

In addition we want the button content to be centred. We will use align-items property to nicely centre all the items inside the flex container:

.top button{
  display: flex;
  align-items: center;

The simple middle part

Not much in here. We don’t need FlexBox here. When we can simply centre the text using text-align property:

  text-align: center;

The social card bottom section

Just like the top section we make .bottom the main flex container and as we want elements on the right we use flex-end to justify them to the end of flex container:

.bottom {
  display: flex;
  justify-content: flex-end;

One more thing is to align the image and the text both centred using align-item property as expected:

.photographer {
  display: flex;
  align-items: center;

This will work. But in HTML the image is before the text. As we don’t want or in reality cannot change the markup we will use FlexBox order property to move the text after the image so it appears after it:

.photographer-name {
  order: 2;

Finally we have our social profile card ready. This is just a simple design which we can refer to as a start to design more complex layouts in FlexBox.

Thank you for reading.

© 2020
Azadeh Faramarzi

This site is created and maintined by Azadeh Faramarzi , A passionate developer, sport and code lover who loves to share and write when she has some time.