htmlcssoocssbemsmacss

What is the difference between a utility and a component in Nicolas Gallaghers' frontend methodology?


In Nicolas Gallaghers' write up about HTML semantics, he outlines a method of structuring html and css in a modular way (influenced by the BEM architecture). He gives an example, which I don’t completely understand:

/* Utility */
.u-utilityName {}

/* Component */
.ComponentName {}

/* Component modifier */
.ComponentName--modifierName {}

/* Component descendant */
.ComponentName-descendant {}

/* Component descendant modifier */
.ComponentName-descendant--modifierName {}

/* Component state (scoped to component) */
.ComponentName.is-stateOfComponent {}

He does not explain this in depth in his article, and I would still like to understand. So I hope someone can answer this.


Solution

  • The utility classes are essentially presentational classes in that modify one presentational aspect of an element. These are useful because they are broadly applicable. You may apply a utility class to a variety of components. Since it isn't specific to a particular component, it isn't necessary to create it as a component modifier.

    State classes are a little different from modifier classes in that state is often added, changed, or removed through JavaScript. So the state classes are just a convention that helps keep straight what classes need to be shared between your stylesheet and scripts. You wouldn't normally want to access your modifier classes in your scripts because this starts to unnecessarily couple them to a specific presentation or component.