css 지정시 class 네이밍에 대해 질문이 있습니다.
153
작성한 질문수 2
안녕하세요. 강의 잘 보고 있습니다.
심플 배너 해설 영상을 보고 있는데 css class 명이 어떨때는 banner-bg 이런식이고 어떤때 에는 cousre__txt 이런식으로 네이밍을 지으시는 것 같은데 권장되는 규칙같은게 있는 건가요??
답변 2
0
안녕하세요.
CSS 강의의 모든 영상은 BEM 컨벤션을 기준으로 하였습니다.
BEM 컨벤션은 인프런 인턴이 답변한 것과 같습니다.
block은 컴포넌트 이름, element는 그 안의 하위 요소, modifier는 스타일이나 상태의 변형을 나타냅니다.
이때, block의 이름이 꼭 단일 단어여야 한다는 규칙은 없습니다.
원한다면 banner-bg 처럼 대시(-) 기호를 이용해서 네이밍을 지어도 됩니다.
그런 관점이라고 생각해주시면 될 것 같습니다 🙂
감사합니다.
0
안녕하세요, 인프런 AI 인턴입니다. rujung1225님.
CSS 클래스 네이밍은 코드의 가독성과 유지보수를 위해 매우 중요합니다. 일반적으로 많이 사용되는 네이밍 컨벤션에는 몇 가지가 있습니다.
BEM(Block Element Modifier): 이 방법은 코드의 구조와 명확성을 높이는 데 도움을 줍니다. 예를 들어,
block__element--modifier와 같은 형태로 사용합니다.block은 컴포넌트의 이름,element는 그 안의 하위 요소,modifier는 스타일이나 상태의 변형을 나타냅니다.Camel Case: JavaScript에서 주로 사용되는 방식으로,
myClassName과 같은 형태를 가집니다. 두 번째 단어부터 대문자로 시작하는 형태입니다.Snake Case: 단어 사이에 언더스코어를 넣는
my_class_name형태로 사용하는 방법입니다. 일관성을 유지하기 쉽지만, CSS에서는 자주 사용되진 않습니다.Kebab Case: 대부분의 CSS에서 많이 볼 수 있는 형식으로
my-class-name처럼 하이픈으로 단어를 구분합니다.
각 컨벤션마다 장단점이 있지만, 중요한 점은 한 프로젝트 내에서 일관성을 유지하는 것입니다. 예를 들어 BEM 규칙을 사용한다면 프로젝트 내 모든 CSS 클래스 네이밍에 이 규칙을 사용하는 것이 좋습니다.
관련된 기존 질문과 답변을 통해 더 많은 정보를 얻으실 수 있습니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
Json 플러그인 사용시 variable collection 없음
0
12
1
배리어블 목록 없음
0
22
3
Token 등록 방법 문의
0
18
1
6-6 실습 문의
0
23
2
섹션5 노션링크 는 따로 없나요?
0
29
2
Part 4에서 강의 연관 노션 정보들이 워드파일에 없습니다.
0
32
2
첨부자료 Part 4 코드 확인 부탁드리겠습니다.
0
27
2
선생님 각 강좌마다 예시로 보여주시는 웹페이지들은 어디서
0
24
1
퍼플렉시티 최소 결제단위 50달러로 바뀐 것 같습니다.
0
54
2
claude plugin 방법 자세히 부탁드려요
0
40
2
강의에 적용한 스크립트를 받아 볼수 있을까요?
0
40
2
최근 코테, 과제 테스트 트렌드
0
67
2
노션 25 인터렉션 구현 파트 안 보입니다!
0
39
2
파트3 13F부분도 짤린거같은데 확인해주세요
0
39
2
Gemini로 진행가능 여부 궁금합니다.
0
59
2
심플갤러리 만들기에서
0
44
2
margin, padding 사용 시기
0
51
2
style 속성마다 박스 형태를 따로 따로 가지나요?
0
52
2
padding-bottom 사용 이유가 무엇인가요?
0
137
2
class명 네이밍 컨벤션 질문입니다!
0
107
2
새로운 강의
0
143
2
섹션18 햄버거 애니메이션 영상이 재생되지 않습니다.
0
125
1
폰트 크기 단위에 대해 질문있습니다.
0
88
2
피그마 활용하기 부분에 대해 질문있습니다.
0
129
1





