bem-methodology-in-css:-a-quick-start-guide

Tom RayTom Ray

Published: January 14th 2020

Updated: January 14th 2020

This is a quick start guide to learning BEM, the component-driven CSS methodology.

If you want to start practicing and applying BEM to your projects, this guide will help you get started.

Ready? Let’s dive in:

BEM Overview

BEM (Block-Element-Modifier) is a CSS naming convention developed by the team at Yandex to improve scalability and maintainability in web development.

Put simply, the idea of BEM is to “divide the user interface into independent blocks” by naming CSS classes in the following methodology:

/* Block component */
.card {}

/* Elements are dependent on their parent block */ 
.card__img {}

/* Modifiers are for incremental style changes */
.card--dark {} 
.card__img--large {}
  1. Block: an independent component that can be reused (e.g. with class name .nav)
  2. Element: a child within a block that cannot be used separately from that block (e.g. with class name .nav__item)
  3. Modifier: a variation in the style of either a block or modifier (e.g. with class name .nav--dark)

Let’s dive into some real CSS examples to get a hang of this thing.

Blocks

Blocks are reusable components. Like buttons, cards or form fields.

When naming your blocks, focus on describing its purpose (i.e. what it is) rather than its state (i.e. what it looks like).

For example, .btn or .nav follows the correct naming convention for a block.

.big or .bright-pink describes how it looks, so doesn’t scale well when you want to change the design later on.



...

...

...


...

...

...

If you’re wondering how to place blocks within blocks (for example, a button inside a nav), here’s a short article to help you with that.

Elements

Inside blocks are where elements live. Elements are dependent on their parent block, and so cannot be used without them.

Elements also have a unique CSS class naming convention which works like this:

.block__element

For example, using the .card component, an element inside the card component (like an image) would have a class name like .card__img.

The element name always appends the block name, separated by a double underscore __.



...

...

...


...

...

...

It’s important to note that the second code snippet avoids using more than 1 selector to target the styles (e.g. like .card img {}).

It’s considered best practice to use a BEM element class and use that directly instead (like .card__img {}).

Following this approach reduces the chance of cascade issues down the line.

Modifiers

When you have varying styles in blocks (or elements), that’s where modifiers come in.

For example, your ‘card’ block might have a light and dark version. Or you might have primary and secondary buttons.

Modifiers have a unique CSS naming convention which works like this:

block--modifier or block__element--modifier.

That’s right- BEM modifiers can be applied to both blocks and elements.

Let’s dive into some bad and good practices:



...

...

...

It’s considered bad practice to use a modifier class in isolation (i.e. without the block or element class).

That’s because the modifier is meant to add incremental style changes to the block.

Therefore, whenever using a modifier, ensure it’s used with the base class:



...

...

...

And that’s it!

Those are the fundamentals to get you off and running with BEM.

If you’re interested to learn more about the ‘why’ behind BEM, I recommend checking out this CSS Tricks article.

Like learning anything new, practicing is key. Give BEM a shot in your next project and see where it takes you!

Download The Free BEM Cheat Sheet

Want to start practicing BEM and looking for a no-nonsense, quick start action guide?

Download a free cheat sheet covering BEM basics so you can dive in and start practicing today.

.

19 comments

  1. Thank you for the auspicious writeup. It in reality was a enjoyment account it.
    Glance advanced to more introduced agreeable from you! By the
    way, how could we be in contact?

  2. It’s an remarkable article in favor of all the internet people; they will obtain advantage from it I am sure.

  3. Greetings! I know this is kind of off topic but I was wondering if you knew where I could locate a captcha plugin for
    my comment form? I’m using the same blog platform as yours and I’m having difficulty finding
    one? Thanks a lot!

  4. Its like you read my mind! You seem to know a lot about this, like you
    wrote the e book in it or something. I feel that you could do with some p.c.
    to drive the message house a bit, however instead of
    that, this is magnificent blog. A fantastic read.
    I will definitely be back.

  5. I was wondering if you ever thought of changing the layout of your website?
    Its very well written; I love what youve got to say. But maybe you could
    a little more in the way of content so people could
    connect with it better. Youve got an awful lot of text for only having 1 or 2 pictures.
    Maybe you could space it out better?

  6. I’ll right away grasp your rss as I can not in finding your
    e-mail subscription link or newsletter service.

    Do you’ve any? Please let me understand in order that I may subscribe.
    Thanks.

  7. Good web site you have got here.. It’s difficult to find high quality
    writing like yours nowadays. I really appreciate people like you!
    Take care!!

  8. Heya i am for the primary time here. I found this board and I find It really useful & it helped me out a lot.
    I hope to provide something back and help others like
    you aided me.

  9. Pingback: keto reddit

Leave a Reply

Your email address will not be published.