Skip to content

Latest commit

 

History

History
42 lines (27 loc) · 1.55 KB

BEM.md

File metadata and controls

42 lines (27 loc) · 1.55 KB

BEM 코딩 스타일

도입 배경

각기 다른 방법으로 스타일시트가 작성되어왔습니다. 스타일시트 일관성 유지를 위해 CSS 방법론 도입을 고려하였고, 그 중 BEM을 선택했습니다. 그 이유는 상대적으로 러닝 커브가 적어 빠르게 도입할 수 있고, 컴포넌트 단위의 개발과 잘 어울려 많은 수의 컴포넌트를 개발하고 있는 팀 상황에 적합했기 때문입니다.

BEM은 필요한 팀에서 선택적으로 사용합니다. BEM을 사용할 때 Class, ID 네이밍 규칙은 적용되지 않습니다.

스타일 가이드

BEM 방법론을 따릅니다. 클래스 이름의 길이를 줄이기 위해 Block, Element, Modifier를 표현하는 방식을 간략하게 변경해서 사용합니다.

  • 컴포넌트 이름은 보통 PascalCase로 표현합니다. Block과 Elemet는 컴포넌트에 대응되는 요소이므로 마찬가지로 PascalCase를 사용합니다.
  • 코드 에디터에서 편리한 블럭 지정을 위해 Element는 언더스코어(_), Modifier는 대시(-)를 접두어로 사용합니다.

Block

PascalCase를 사용하여 표현합니다.

<div class="Card">...</div>

Element

언더스코어(_)와 PascalCase를 사용하여 표현합니다.

<div class="Card">
  <h2 class="Card_Title">...</h2>
</div>

Modifier

대시(-)와 camelCase를 사용하여 표현합니다.

<div class="Card Card-disabled">
  <h2 class="Card_Title">...</h2>
</div>