각기 다른 방법으로 스타일시트가 작성되어왔습니다. 스타일시트 일관성 유지를 위해 CSS 방법론 도입을 고려하였고, 그 중 BEM을 선택했습니다. 그 이유는 상대적으로 러닝 커브가 적어 빠르게 도입할 수 있고, 컴포넌트 단위의 개발과 잘 어울려 많은 수의 컴포넌트를 개발하고 있는 팀 상황에 적합했기 때문입니다.
BEM은 필요한 팀에서 선택적으로 사용합니다. BEM을 사용할 때 Class, ID 네이밍 규칙은 적용되지 않습니다.
BEM 방법론을 따릅니다. 클래스 이름의 길이를 줄이기 위해 Block, Element, Modifier를 표현하는 방식을 간략하게 변경해서 사용합니다.
- 컴포넌트 이름은 보통 PascalCase로 표현합니다. Block과 Elemet는 컴포넌트에 대응되는 요소이므로 마찬가지로 PascalCase를 사용합니다.
- 코드 에디터에서 편리한 블럭 지정을 위해 Element는 언더스코어(_), Modifier는 대시(-)를 접두어로 사용합니다.
PascalCase를 사용하여 표현합니다.
<div class="Card">...</div>
언더스코어(_)와 PascalCase를 사용하여 표현합니다.
<div class="Card">
<h2 class="Card_Title">...</h2>
</div>
대시(-)와 camelCase를 사용하여 표현합니다.
<div class="Card Card-disabled">
<h2 class="Card_Title">...</h2>
</div>