Categories: CSS

CSS 선택자 종류와 설명

CSS 선택자는 웹 개발에서 중요한 개념 중 하나입니다.
웹 페이지를 디자인하고 스타일링 하는데 사용되는 CSS의 핵심 부분 중 하나로,
선택자를 올바르게 이해하는 것이 중요합니다.

CSS 선택자의 기본 개념

CSS 선택자는 웹 페이지의 요소를 선택하여 스타일을 적용하는데 사용됩니다. 웹 페이지에서 어떤 부분을 선택하고 어떻게 스타일을 적용할지를 정의하는데 선택자가 필수적입니다. 간단한 선택자부터 그룹화 및 속성 선택자까지 다양한 유형이 있습니다.

CSS 전체 선택자

전체 선택자는 모든 요소를 선택합니다. 기본적으로 모든 스타일을 적용하고자 할 때 사용됩니다.

* {
  color: aqua;
}
CSS

CSS 요소 선택자

요소 선택자는 HTML 요소를 선택합니다. 예를 들어, p는 모든 단락을 선택합니다.

p {
  color: pink;
}
CSS

CSS ID 선택자

ID 선택자는 특정 ID를 가진 요소를 선택합니다. #box은 ID가 ‘box’인 요소를 선택합니다.

#box {
  background-color: blue;
}
CSS

CSS Class 선택자

Class 선택자는 특정 클래스를 가진 요소를 선택합니다. .tag는 클래스가 ‘tag’인 모든 요소를 선택합니다.

.tag {
  background-color: yellow;
}
CSS

CSS 선택자의 조합과 그룹화

선택자를 조합하거나 그룹화하면 스타일을 더 효율적으로 적용할 수 있습니다.
예를 들어, h1, h2는 h1과 h2 요소에 동일한 스타일을 적용합니다.

h1,h2 {
  color: skyblue;
}
CSS

CSS 속성 선택자

속성 선택자는 특정 HTML 속성을 가진 요소를 선택합니다. input[type=”password”]는 ‘type’ 속성이 ‘password’인 요소를 선택합니다.

input[type="password"] {
  color: green;
}
CSS

CSS 자손 선택자

자손 선택자는 띄어쓰기를 사용하여 부모 요소와 그 자손 요소를 나타내는 CSS 선택자입니다. 부모 요소와 자손 요소 사이에 공백을 두어 나타내며, 이를 통해 특정한 계층 구조의 요소를 스타일링 할 수 있습니다.

footer a {
  color: pink;
}
CSS

CSS 자식 선택자

자식 선택자는 부모 요소의 직계 자식 요소를 선택하기 위한 선택자입니다.
이 선택자는 > 기호를 사용하여 부모와 직계 자식 요소를 나타냅니다.

footer > a {
  color: pink;
}
CSS

CSS 인접 선택자

인접 형제 선택자는 같은 부모를 가지고 있고 같은 부모에서 형제 관계에 있는 다음 요소를 선택하기 위한 선택자입니다. 이 선택자는 + 기호를 사용하여 표시됩니다.

/* input 다음에 오는 button 을 선택 */
input + button {
  background-color: pink;
}
CSS

CSS 가상 클래스

가상 클래스는 요소의 특정 상태를 선택합니다. :hover는 마우스를 요소 위에 올렸을 때 상태를 나타냅니다.

a:hover {
  text-decoration: underline;
}
CSS

CSS 가상 요소

가상 요소 선택자는 문서의 일부가 아닌 특정한 부분이나 상태를 선택하기 위한 CSS 선택자 중 하나입니다. 가상 요소는 존재하지 않는 요소를 말하며, 주로 특정한 스타일을 적용하기 위해 사용됩니다. 가상 요소 선택자는 두 개의 콜론(::)을 사용하여 정의되며, 일반적으로 다음과 같은 형식을 가집니다.

span::before {
  content: "가상 요소";
}
CSS

결론

CSS 선택자는 웹 개발에서 스타일을 적용하는 핵심 도구입니다.
선택자를 효과적으로 활용하면 웹 페이지의 디자인과 스타일링을 더욱 유연하게 조작할 수 있습니다. 선택자의 다양한 유형을 이해하고 적재적소에 활용하는 것이 좋습니다.
이를 통해 더 멋진 웹 페이지를 구현할 수 있습니다.

suover

Recent Posts

Java 자바 중첩 클래스(Nested Class)란?

중첩클래스란? 자바에서 중첩 클래스(Nested Class)는 자바 프로그래밍의 중요한 개념 중 하나로, 클래스 안에 다른 클래스를…

2개월 ago

Java 자바 Enum 열거형 사용법

Enum이란? Enum은 "enumeration"의 줄임말로, 특정 값들의 집합을 정의할 수 있는 특별한 클래스입니다. 예를 들어, 요일,…

2개월 ago

Java 자바 래퍼 클래스(Wrapper Class)란? 래퍼 클래스의 필요성

래퍼 클래스(Wrapper Class)란? 자바에서 래퍼 클래스는 기본 데이터 타입(Primitive Data Type)을 객체(Object)로 감싸는 클래스입니다. 자바의…

2개월 ago

Java 자바 StringBuilder 개념 및 특징 주요 메소드

서론 Java에서 문자열을 다룰 때, 문자열의 변경이 빈번하게 발생하는 경우라면 StringBuilder 클래스를 사용하는 것이 매우…

2개월 ago

웹 개발 FitOn 팀 프로젝트 회고

서론 현대인들은 점점 더 운동과 건강에 대한 관심을 가지고 있으며, 이를 체계적으로 관리하고 공유할 수…

3개월 ago

Java 자바 String 클래스 특징 및 메소드

String 클래스란? 자바에서 String 클래스는 가장 널리 사용되는 클래스 중 하나입니다. 문자열 시퀀스를 나타내며, 문자열을…

3개월 ago