가상 클래스와 가상 요소 기초
CSS에서는 기본 선택자 외에도 특별한 상태나 위치를 지정할 수 있는 가상 클래스와 가상 요소라는 강력한 도구를 제공합니다. 이들을 활용하면 HTML 구조를 변경하지 않고도 더욱 세밀하고 동적인 스타일링이 가능해집니다.
1. 가상 클래스 선택자
가상 클래스 선택자(Pseudo-class selectors)는 요소의 특정 상태를 선택할 수 있게 해줍니다. 이들은 콜론(:
)을 사용하여 표현됩니다.
1.1 동적 가상 클래스
동적 가상 클래스는 사용자의 동작에 따라 변화하는 상태를 선택합니다.
1.1.1 :link
아직 방문하지 않은 링크를 선택합니다.
1.1.2 :visited
이미 방문한 링크를 선택합니다.
1.1.3 :hover
마우스 포인터가 올라간 요소를 선택합니다.
1.1.4 :active
마우스로 클릭하고 있는 요소를 선택합니다.
1.1.5 :focus
현재 초점을 가진 요소를 선택합니다.
이러한 동적 가상 클래스들을 조합하여 사용하면 사용자 상호작용에 따른 다양한 시각적 피드백을 제공할 수 있습니다. 예를 들어, 링크에 이 모든 상태를 적용할 수 있습니다:
이처럼 동적 가상 클래스는 사용자의 동작에 따라 요소의 스타일을 변경할 수 있습니다.
1.2 구조적 가상 선택자
구조적 가상 선택자는 문서 구조 내에서 요소의 위치에 따라 선택합니다.
1.2.1 :first-child
와 :last-child
:first-child
는 형제 요소 그룹 중 첫 번째 요소를, :last-child
는 마지막 요소를 선택합니다.
body의 직계 자손의 경우 :first-child
선택자는 사용가능하지만,
:last-child
선택자가 적용되지 않습니다.
1.2.2 :nth-child
부모 요소 내의 모든 자식 요소 중에서 지정된 순서에 있는 요소를 선택합니다. 이 선택자는 요소의 타입과 관계없이 순서만을 고려합니다.
- 정수값: 특정 순서의 요소를 선택
- 키워드
- odd: 홀수 번째 요소 선택
- even: 짝수 번째 요소 선택
- 수식: an+b 형태의 수식 사용 가능 (여기서 n은 0부터 시작하는 정수, a와 b는 정수값)
- 음수값: 요소의 뒷부분이나 특정 범위의 요소들을 선택할 때 유용
- 예:
(-n+3) - 처음 3개 요소 선택
- 예:
1.2.3 :nth-of-type
부모 요소 내에서 같은 타입의 형제 요소 중 지정된 순서에 있는 요소를 선택합니다. 이 선택자는 요소의 타입을 고려하여 순서를 계산합니다.
1.2.4 :only-of-type
:only-of-type
는 동일한 유형의 형제가 없는, 형제 요소 중 유일하게 사용된 태그를 선택합니다.
1.2.5 :not
1.2.6 :root
이러한 구조적 가상 선택자들을 활용하면 HTML 구조를 변경하지 않고도 특정 위치의 요소들에 스타일을 적용할 수 있습니다. 이는 특히 반복적인 구조를 가진 리스트나 그리드 레이아웃에서 유용하게 사용될 수 있습니다.
2. 가상 요소
가상 요소(Pseudo-elements)는 말 그대로 가상의 요소를 만드는 것입니다. 선택한 요소의 특정 부분에 스타일을 적용할 수 있게 해줍니다. 이들은 이중 콜론(::
)을 사용하여 표현됩니다.
2.1 ::before
와 ::after
::before
와 ::after
는 선택한 요소의 내용 앞이나 뒤에 새로운 요소를 만들어 새로운 콘텐츠를 추가할 수 있게 해줍니다. 이들은 주로 content 속성과 짝을지어 장식적인 요소를 추가하거나, 기능적인 목적으로 사용됩니다. 빈태그 img
br
input
에는 적용할 수 없습니다.
2.2 ::placeholder
<input>
과 <textarea>
요소의 플레이스홀더 텍스트에 스타일을 적용할 수 있게 해줍니다. 플레이스홀더는 사용자에게 입력 필드에 어떤 정보를 입력해야 하는지 안내하는 역할을 합니다.
입력 필드에 텍스트가 입력되면 플레이스홀더는 사라집니다. 접근성을 고려한다면 플레이스홀더에만 의존하지 말고 적절한 레이블도 함께 사용해야 합니다.
의사 요소 - CSS: Cascading Style Sheets | MDN