Introduction to Flexbox

Get introduced to flexbox and learn flex properties like flex-direction, flex-wrap, and flex-flow

We'll cover the following

Flexbox does a superb job of centering multiple items and is also great at spacing items of different sizes. It’s not, however, very good at lining up rows and columns or keeping items in a structured grid format.

Columns, as we saw earlier, excel at making text columns, but can be unruly and difficult when laying out things other than text.

Flexbox came before CSS grid and has better browser support (although CSS grid has excellent browser support, too). Flexbox shines

  • when doing single rows/columns
  • for multiple rows when fine-grained control isn’t required
  • with objects of varying size

If you need pixel-perfect control over where elements are, flexbox will make you tear your hair out, but if your layout needs are more approximate or you have varying-sized items, flexbox is an excellent weapon of choice.

Flex properties

display: flex: This goes on the container element, which is the parent element of the items you want to organize. If you don’t have a container element, you need to create one.

.undead-parent {
    display: flex;
}

flex-direction: This sets how the elements are laid out, either as columns or rows, and sets the axes you’ll be using. Since it can change which direction acts as the block or inline direction, when working with flexbox, it’s best to call them the main-axis and the cross-axis. When flex-direction defines rows, the main-axis/direction is the inline direction. But when you change the flex-direction to columns, you change the main-axis to the block direction, while elements and text within your flex items still follow the default inline and block directions.

Since this can get more confusing than a zombie at a midnight showing of “Night of the Living Dead”, we’ll stick with the main-axis and cross-axis. Just remember that they can flip, depending on what you choose for the flex-direction. Also, for simplicity, we’ll assume that you’re using a left-to-right language such as English, making your inline direction left to right and your block direction up and down. If you’re using a different language or a different writing-direction, the directions will change.

.undead-parent {
    flex-direction: column;
}
  • column: Displays items vertically, starting with the first element at the top.

  • column-reverse: Displays items vertically, starting with the first element at the bottom.

  • row: Displays items horizontally, starting with the first element at the left.

  • row-reverse: Displays items horizontally, starting with the first element at the right.

Get hands-on with 1300+ tech skills courses.