:active
가상 클래스
:active
가상 클래스 선택자는
요소에 마우스 커서를 올려 놓고 누르는 순간부터 떼는 시점까지 해당 요소를 선택합니다.
이 기간 동안에만 미리 정의된 스타일이 적용되므로, 사용자에게 인터랙티브하고 동적인 사용자 경험을 제공합니다.
사용자가 마우스를 사용할 때 마우스 커서를 요소에 올려 놓고 마우스 버튼을 누르는 순간부터 떼는 시점까지의 상태를 CSS에서 통상적으로 '활성화(active)' 상태라고 부릅니다.
주의하세요!
'클릭(click)'은 사용자가 마우스 버튼을 눌렀다가 뗄 때를 의미합니다.
CSS에서는 이러한 상태에 대한 선택자가 없으며, 자바스크립트의 click 이벤트로 처리합니다.
예제
이 예제에서는 버튼 요소를 마우스로 누를 때에만 배경색이 orange
에서 black
으로 변경됩니다.
:active
가상 클래스의 형식은 다음과 같습니다.
구문
주의할 점
:acitve
가상 클래스로 정의한 스타일은
자신보다 뒤에 위치하고 적어도 동일한 구체성 값(명시도)을 가진 다른 상태에 관련된 가상 클래스(:link
, :visited
, :hover
)가 덮어씁니다. 예를 들어, :active
가 :hover
앞에 배치되어 있을 경우에는 :hover
가 :active
를 덮어씁니다.
알아두세요!
상태에 관련된 가상 클래스 선택자인 :link
, :visited
, :hover
, :active
는 스타일시트에서 배치 순서가 정해져 있습니다. 그래야 유효하게 작동합니다.
LoVe HAte 순서(:link
→ :visited
→ :hover
→ :active
)라고 기억하면 쉬운데, 이 순서대로 배치하지 않으면 후순위가 선순위보다 먼저 배치되어 있을 경우 해당 후순위는 이 후에 배치되는 선순위가 스타일을 덮어씁니다.
따라서, 상태와 관련된 가상 클래스들과 적절하게 스타일하려면 LoVe HAte 순서(:link
→ :visited
→ :hover
→ :active
)를 따라, :link
및 :visited
뒤에 :hover
를 배치하고 :active
앞에 배치해야 합니다.
:hover
는 요소에 마우스 커서를 올려 놓았을 때 해당 요소를 선택하는 가상 클래스입니다.
다음은 LoVe HAte 순서와 다르게 :active
가 :hover
앞에 배치되어 있어서 :hover
가 :active
를 덮어쓰는 예제입니다.
위 예제를 보면, :active
가 :hover
앞에 배치되어 있어서 button:hover
에서 선언한 버튼의 색(gray
)이 사용자가 버튼에 마우스 커서를 올려 놓은 상태에서 마우스 버튼을 누르는 순간부터 떼는 시점까지 선택되는 button:active
에서 선언한 버튼의 색(black
)을 덮어쓰기하기 때문에 button:active
에서 선언한 버튼의 색(black
)이 적용되지 않음을 주의해야 합니다.
다음은 LoVe HAte 순서대로 :hover
가 :active
앞에 배치되어 있어서 올바르게 스타일이 적용되는 예제입니다.
알아두세요!
마우스를 사용하지 않는 모바일과 같은 터치스크린에서는 :hover
와 :active
를 같이 사용하여 스타일 할 경우에 동작이 브라우저마다 다를 수 있으며, 제한적이거나 의도한 대로 작동하지 않을 수 있습니다.
HTML5에서 레이블을 누를 시 컨트롤 요소의 :active
상태 적용
브라우저 호환성
선택자 |
데스크탑 Chrome
|
데스크탑데스크탑 Edge
|
데스크탑 Firefox
|
Safari
|
---|---|---|---|---|
:active
|
1 | 12 | 1 | 1 |
명세서
명세서 사양 | |
---|---|
:active
|
Selectors Level 4 #the-active-pseudo |