홈으로 | 무료회원가입 | 아이디/비번찾기
추천음악방송
CSS셀렉터 정리(3)
12년 전
유사요소(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

text
sub title

간접 셀렉터(General sibling combinator)
E ~ F

E라고 하는 요소의 뒤에 출현하는 F라고 하는 요소에 스타일을 지정한다. 즉, E라고 하는 요소의 동생 요소가 대상이 된다. CSS3에 정의되어 있다.

CSS3에서는 큰폭으로 셀렉터가 확장 되었고 브라우저에서 구현이 된다면 불필요한 class속성이나 id속성을 줄일 수 있을 것 같다. 또 표현의 폭이 그만큼 넓어지고 JavaScript로 구현 하던 부분들도 CSS만으로도 표현이 가능한 부분이 늘어날 것 같다.

현재 CSS3가 Working Draft 상태이기 때문에 변경될 가능성도 있고 역시 IE가 발목을 잡는 부분도 많이 있을 것 같다. 브라우저에 따라 표시되지 않더라도 크게 영향을 끼치지 않는 부분이라면 지금이라도 사용이 가능한 부분도 많이 있지만 클라이언트가 모든 브라우저에서 전부 똑같이 해달라고 하는 대략 난감한 경우도 생길 수도 있다(실제로 예전에 그런 경우가 있었음..;). 그래도 클라이언트가 해달라면 해줘야 한다!

참고:css셀렉터에 관해 css3.info에서 좋은 정보를 많이 제공하고 있다.
추천추천 : 511 추천 목록
번호 제목
3,033
 PHP 정규식 정리
3,032
 PHP 정규식을 활용한 태그 및 특정 문자열 제거 및 추출 방법
3,031
 php 크롤링 또는 파싱 함수, 정규식 모음
3,030
 제이쿼리 기본 명령어
3,029
 웹페이지 가로 모드세로 모드 인식하기
3,028
 모바일 웹 화면 강제 회전(가로모드 고정)
3,027
 [HTML5]에서 frameset 대체 방법과 iframe 속성
3,026
 HTML <Audio> 사용법
3,025
 윈도우10 시스템파일 손상 (초간단 오류 복구방법!!)
3,024
 PHP 파일 존재 여부 파악하기(로컬 파일 존재 및 원격지 파일 존재)
3,023
 [CSS] 박스 세로 가운데 중앙 정렬 6가지
3,022
 CSS Layout 수평 & 수직 정렬
3,021
 여러 도메인들 간 쿠키 공유하기
3,020
 태그 사이에 있는 텍스트를 추출
3,019
 [JQuery] textbox focus on off일때 숫자 콤마 보여주기
3,018
 쿠키 생성,가져오기,삭제
3,017
 사용자 함수 모음
3,016
 마우스,키보드 제한 ( 오른쪽클릭,드래그,영역선택등..)
3,015
 [HTML5] <video> - DOM으로 제어하기
3,014
 HTML5 video 태그에서 영상 좌우반전
3,013
 PHP - 특정 태그 및 문자열 추출, 제거
3,012
 [PHP] define과 defined의 차이
3,011
 우클릭 완벽차단 스크립트
3,010
 iframe 높이 100% 맞추기
3,009
 curl 함수를 이용한 HTTP REFERER 변경
목록
뮤직트로트 부산광역시 부산진구 가야동 ㅣ 개인정보취급방침
Copyright (C) musictrot All rights reserved.