CSS셀렉터 정리(3)
이번 포스팅에서는 유사요소를 중심으로 정리한다(마지막회).
CSS3에서는 유사클래스와 유사요소를 명확하게 구별하고 있다. 유사요소는 “:”을 2회 사용하여 “::”이라고 기술하도록 되어 있다. “::”라고 기술하는 방식은 상당수의 모던 브라우저가 대응하고 있다.
※加藤善規(카토 요시키)씨의 CSS セレクタに関するおさらい 3 | WWW WATCH를 번역한 내용입니다.
유사요소(pseudo-element)
E::first-line
E라고 하는 요소의 첫번째 행에만 스타일을 적용한다. CSS1에 정의되어 있다. 첫번째 행은 font size나 브라우저의 윈도우 사이즈 등 다양한 조건에 따라 바뀌기 때문에 주의가 필요하다. 덧붙여 블록요소에만 사용 할 수 있고 지정 할 수 있는 프로퍼티에도 제한이 있다.
p {
margin-left:1em;
}
p::first-line {
margin-left:-1em;
}
예를 들어 “※”등을 사용한 주석문에서 첫번째 행에 사용된 “※”만큼 두번째 행도 인덴트하고 싶은 경우에도 사용 할 수 있다.
E::first-letter
E라고 하는 요소에 최초에 등장하는 첫문자에만 스타일을 지정한다. CSS1에 정의되어 있다. 첫번째 문자가 특정문자(인용부호나 괄호등)인 경우 그 다음 문자와 함께 스타일을 적용한다. ::first-line 유사요소와 같이 블록요소에만 사용 할 수 있고 지정 할 수 있는 프로퍼티에도 제한이 있다.
E::selection
유저가 선택한 문서에 스타일을 적용한다. 예를 들면 텍스트를 마우스로 드랙 했을 때의 외형을 바꿀 수 있다. CSS3에 정의되어 있다.
p::selection {
background:#f00;
color:#fff;
}
E::before
E::after
E라고 하는 요소에 포함된 내용의 앞(::before), 뒤(::after)에 지정한 내용을 생성한다. content프로퍼티와 함께 사용해서 텍스트나 이미지 등을 추가한다. CSS2에 정의되어 있다.
p.note::before {
content:url(image/note-icon.png);
margin:0 2px;
}
li.new::after {
content:"new!";
color:#f00;
}
클래스 셀렉터(Class selectors)
E.warning
class속성 값에 따라 스타일을 적용한다. CSS1에 정의되어 있다.
ID 실렉터(ID selectors)
E#myid
id속성 값에 따라 스타일을 적용한다. CSS1에 정의되어 있다.
부정 유사클래스(Negation pseudo-class)
E:not(s)
E라고 하는 요소중에서 “s”가 아닌 것에 스타일을 적용한다. CSS3에 정의되어 있다.
input {
vertical-align:middle;
}
input:not([type="text"]) {
vertical-align:top;
}
라고 하여 type=”text” 이외의 input요소에만 다른 스타일을 지정하는 것도 가능하다.
자손 셀렉터(Descendant combinator)
E F
복수의 실렉터를 조합해 사용하는 방법이다. 자손 셀렉터는 부모요소에 포함된 모든 자손 요소에 스타일을 적용한다. 유니버살 셀렉터나 속성 셀렉터등과 조합해서 사용할 수 있다. CSS1에 정의되어 있다.
p span.note {
color:red;
}
ul li * li {
margin-left:2em;
}
자식 셀렉터(Child combinator)
E > F
자식 실렉터는 부모 요소의 직접적인 자식요소에 스타일을 적용한다. 손자 요소 이하에는 적용 되지 않는다. CSS2에 정의되어 있다.
인접 셀렉터(Adjacent sibling combinator)
E + F
E라고 하는 요소 중에서 직접적인 동생 요소인 F라고 하는 요소에 스타일을 적용한다. CSS2에 정의되어 있다.
형제 요소란 어떤 부모 요소안에서 동렬로 존재하는 요소 가운데 앞(형), 뒤(동생)에 존재하는 요소를 가리킨다. 직접적인 동생 요소란 E라고 하는 요소와 동렬로, E라고 하는 요소의 바로 뒤에 인접해 존재하는 요소를 가리킨다. 예를 들면 다음과 같은 경우 h2요소는 h1요소의 직접적인 동생 요소이다.
title
sub title
하지만 아래와 같은 경우에는 h2는 h1의 직접적인 동생 요소가 아니다.
title
textsub title
간접 셀렉터(General sibling combinator)
E ~ F
E라고 하는 요소의 뒤에 출현하는 F라고 하는 요소에 스타일을 지정한다. 즉, E라고 하는 요소의 동생 요소가 대상이 된다. CSS3에 정의되어 있다.
CSS3에서는 큰폭으로 셀렉터가 확장 되었고 브라우저에서 구현이 된다면 불필요한 class속성이나 id속성을 줄일 수 있을 것 같다. 또 표현의 폭이 그만큼 넓어지고 JavaScript로 구현 하던 부분들도 CSS만으로도 표현이 가능한 부분이 늘어날 것 같다.
현재 CSS3가 Working Draft 상태이기 때문에 변경될 가능성도 있고 역시 IE가 발목을 잡는 부분도 많이 있을 것 같다. 브라우저에 따라 표시되지 않더라도 크게 영향을 끼치지 않는 부분이라면 지금이라도 사용이 가능한 부분도 많이 있지만 클라이언트가 모든 브라우저에서 전부 똑같이 해달라고 하는 대략 난감한 경우도 생길 수도 있다(실제로 예전에 그런 경우가 있었음..;). 그래도 클라이언트가 해달라면 해줘야 한다!
참고:css셀렉터에 관해 css3.info에서 좋은 정보를 많이 제공하고 있다.









2007-01-15 at 22:06:00
정말 잘 봤습니다~
두고두고 볼 수 있게 제 홈에 이 포스팅 링크 걸어놓겠습니다~ :-)
2007-01-16 at 09:04:14
도움이 되었다니 기쁩니다:-)
2010-01-25 at 01:07:10
오오… 쉽게 설명해주셔서 감사합니다! 북마크해두고 두고두고 보겠습니다!