가상 선택자 :after 의미를 모르겟어여..

 

.container:after { content:""; clear:both; display:block; }

가상 선택자란 실제로는 존재하지 않는 요소나 특수한 상황에서만 발생하는 동적인 요소를 CSS 명령으로 제어하는 기법 입니다. 가상 선택자는 다시 '가상 클래스 선택자'와 '가상 요소 선택자'로 구분할 수 있는데요. 가상 클래스 선택자(:link, :visited, :hover,:active, :focus, :first-child)는 특정 요소에 마치 동적으로 class를 부여한 것과 같은 이치로 이용할 수 있습니다. 가상 요소 선택자(:first-line, :first-letter, :before, :after)는 실제로 존재하지 않는 요소를 마치 존재하는 것처럼 이용하는 기법 입니다. :after라는 가상 요소 선택자는 content 라는 속성을 이용해서 .container 블럭이 끝나기 직전 content 속성의 값 "*" 을 화면에 출력할 수 있습니다. 이렇게 생성된 요소에 clear:both 속성을 부여하면 자식의 높이를 부모에게 전달할 수 있는데 실제로 HTML 코드에는 빈 요소가 존재하지 않기 때문에 가장 이상적인 방법이라고 할 수 있습니다. 그러나 IE 6~7 브라우저는 가상 요소 선택자를 지원하지 않습니다. 

 

이게 무슨말인지 쉽게 설명좀 부탁드립니다 ㅜㅜ

 

|

댓글 7개

쉽게 말하자면 내가 원할때 붙였다 뗐다 할수 있는 접미사 같은겁니다. 음.. 더 어려운가요 ;;;
물+컵 = 물컵 이런식으로 사용하는것처럼요 .
감사합니다. 쉽게 이해되었습니다!
.container:after { content:"bbb"; clear:both; display:block; }
라고 하면
<div class="container">aaa</div>
aaa 다음에 bbb 가 나옵니다.
즉..
코드에는 없지만 가상으로 있는거 처럼 꾸며준다는 얘기죠...
감사합니다. 구체적으로 예를 들어주시니 이해되네여 ^___^
저는 :before / :after 가상 클래스를 많이 사용합니다.
특히나 오토 넘버링도 돼서 챕터나 세부 카테고리를 작성할 때에는 counter-increment를 사용하는 편입니다.
감사합니다 다음에 카운터인크리먼트도 공부해볼께여~
:before / :after 의 기본 개념은 '가상 텍스트노드 생성' 입니다. 단순히 가상 요소- 라기보단 '텍스트'요소라는 정의가 붙어있습니다.
보통들 기본 inline 요소로 만들어진 가상요소를 CSS에서 display:block 처리해주어서 블록요소로 만든다음에 사용하죠.
div:after -> HTML로 따지자면 종료태그의 바로 전라인에 content:"" 에 입력한 텍스트를 텍스트노드로 가상으로 삽입해주게됩니다.
:before 시작태그가 열린 바로다음줄에 (제일 첫번째 자식컨텐츠) content 로 입력해준 텍스트노드를 마찬가지로.. 가상으로 만들어줍니다 :) ㅎㅎ
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
11년 전 조회 2,269
11년 전 조회 1,845
11년 전 조회 1,591
11년 전 조회 1,245
11년 전 조회 994
11년 전 조회 1,173
11년 전 조회 1,058
11년 전 조회 1,539
11년 전 조회 2,353
11년 전 조회 1,014
11년 전 조회 1,196
11년 전 조회 1,858
11년 전 조회 1,529
11년 전 조회 1,436
11년 전 조회 1,356
11년 전 조회 1,276
11년 전 조회 3,613
11년 전 조회 1,264
11년 전 조회 1,874
11년 전 조회 2,126
11년 전 조회 1,442
11년 전 조회 1,435
11년 전 조회 1,437
11년 전 조회 892
11년 전 조회 1,293
11년 전 조회 1,624
11년 전 조회 1,584
11년 전 조회 954
11년 전 조회 1,302
11년 전 조회 1,071
11년 전 조회 1,833
11년 전 조회 1,470
11년 전 조회 857
11년 전 조회 2,284
11년 전 조회 6,751
11년 전 조회 1,409
11년 전 조회 1,260
11년 전 조회 1,194
11년 전 조회 1,055
11년 전 조회 1,583
11년 전 조회 966
11년 전 조회 3,542
11년 전 조회 1,373
11년 전 조회 1,791
11년 전 조회 1,151
11년 전 조회 2,789
11년 전 조회 1,420
11년 전 조회 2,705
11년 전 조회 2,069
11년 전 조회 2,589
11년 전 조회 1,537
11년 전 조회 2,657
11년 전 조회 1,468
11년 전 조회 1,170
11년 전 조회 1,170
11년 전 조회 5,549
11년 전 조회 1,382
11년 전 조회 922
11년 전 조회 881
11년 전 조회 1,249
11년 전 조회 1,589
11년 전 조회 2,020
11년 전 조회 2,319
11년 전 조회 1,226
11년 전 조회 1,539
11년 전 조회 1,482
11년 전 조회 1,124
11년 전 조회 893
11년 전 조회 2,312
11년 전 조회 1,550
11년 전 조회 3,376
11년 전 조회 1,301
11년 전 조회 1,135
11년 전 조회 2,236
11년 전 조회 2,883
11년 전 조회 2,243
11년 전 조회 3,287
11년 전 조회 1,671
11년 전 조회 3,413
11년 전 조회 927
11년 전 조회 1,214
11년 전 조회 2,102
11년 전 조회 2,442
11년 전 조회 1,115
11년 전 조회 2,951
11년 전 조회 3,136
11년 전 조회 1,668
11년 전 조회 2,333
11년 전 조회 1,199
11년 전 조회 1,527
11년 전 조회 1,205
11년 전 조회 2,410
11년 전 조회 2,312
11년 전 조회 1,305
11년 전 조회 5,432
11년 전 조회 2,479
11년 전 조회 3,205
11년 전 조회 2,050
11년 전 조회 1,088
11년 전 조회 2,160
🐛 버그신고