<!-- #parent>h2+ul>li*2 -->
<div id="parent">
<h2>h2 안녕</h2>
<ul>
<li>li Hello</li>
<li>li 니하오</li>
</ul>
<!-- div#child>h2+ul>li*2 -->
<div id="child">
<h2>h2 잘가</h2>
<ul>
<li>li byebye</li>
<li>li 짜이찌엔</li>
</ul>
</div>
</div>
위 코드에서 직계자식과 후손에 대해 배워보자.
직계자식 & 후손
data:image/s3,"s3://crabby-images/d66cb/d66cbee1a6383f8ee40625642dfb5e8de5b83784" alt=""
data:image/s3,"s3://crabby-images/2afbc/2afbcf43fc497a0b98ff2160f567977431019bfa" alt=""
직계자식인 parent만 h2에 대해서 노란색 배경이 설정되었다.
부모의 경우 '>' 를 사용하고, 후손의 경우 ' ' (띄어쓰기)를 사용한다.
후손에 대해 underline을 지정해주었는데, 부모 및 자식에 대해 전부 설정되었다.
부모 아래에 있는 ul, li에 대해서 색을 빨간색으로 지정해주었더니 parent아래만 빨간색으로 지정되었다.
자식에 대해서 ul, li에 대해 색을 파란색으로 지정해주었더니 child아래만 파란색으로 지정되었다.
<!-- div>span#front$*5 -->
<div>
<span id="front1">html</span>
<span id="front2">css</span>
<span id="front3">javascript</span>
<span id="front4">jquery</span>
<span id="front5">geolocation</span>
<strong id="front6">webstorage</strong>
</div>
위 코드에 대해서 형제요소에 대해 알아보자.
형제요소
data:image/s3,"s3://crabby-images/c347b/c347bfe48b65100553c61ef537c13df41d9ad4e1" alt=""
data:image/s3,"s3://crabby-images/96712/967128435d7244c0e40fdc4bfda57e30afc1eb42" alt=""
front3에 대해서 연두색이 설정되었다. *(아스타리카) 는 전체선택이라는 의미.
data:image/s3,"s3://crabby-images/2730b/2730b6afae1b2535c3094a809df1c4e5e31f7a45" alt=""
data:image/s3,"s3://crabby-images/81d97/81d97a35c88702494f834a694b92d3d2d39e340c" alt=""
front 3 부터 모든 형제요소가 line-through가 적용되었다. 이때, front6은 span태그가 아닌 strong태그라 적용되지 않았다.
<fieldset>
<legend>속성관련</legend>
<!-- (input+br)*5 -->
<input type="text"><br>
<input type="text" name="username"><br>
<input type="email" name="useremail"><br>
<input type="text" name="petname"><br>
<input type="text" name="myusage"><br>
</fieldset>
위 코드에 대해 속성 태그들을 알아보자.
속성 name
data:image/s3,"s3://crabby-images/a8fa7/a8fa79faad4a13a2db912ac4daaed8d76d70a596" alt=""
data:image/s3,"s3://crabby-images/ec03e/ec03eb2940fe5a087eba3691d620bcf375325ff8" alt=""
name속성이 존재하는 것들만 배경색이 채워졌다.
속성 type
data:image/s3,"s3://crabby-images/c267c/c267c824a0cf6f363658ba4736b81b5257d7ab0c" alt=""
data:image/s3,"s3://crabby-images/dab7c/dab7c8af1b18035189aba4146d9212a74aa4734c" alt=""
type이 text인 것들만 배경색이 채워졌다.
속성 ^=
data:image/s3,"s3://crabby-images/96e43/96e435d8e067fa8886ca86c31c6962b5b84c0084" alt=""
data:image/s3,"s3://crabby-images/6edb0/6edb0c3ed12e6902896524c903e545c601a06254" alt=""
^=는 ~로 시작하는 이라는 의미이다.
name이 user로 시작하는 두번째와 세번째 태그만 색이 채워졌다.
속성 $=
data:image/s3,"s3://crabby-images/9b03b/9b03b24cc2f9539cd98b572501a9f62e40e47507" alt=""
data:image/s3,"s3://crabby-images/f43ae/f43ae1a377ad320707d152e151a6b42e85193117" alt=""
$= 는 ~로 끝나는 이라는 뜻이다. petname, username을 가지는 2,4번째만 색이 채워졌다.
속성 *=
data:image/s3,"s3://crabby-images/3d805/3d805c7f584d47e5fba33433a6a7fb59347a9495" alt=""
data:image/s3,"s3://crabby-images/bcb33/bcb334da1ccb4a6ca0013762946ca7b200d4d6d9" alt=""
*=는 ~가 포함되는 이라는 뜻이다. us가 포함된 세개의 태그가 색이 채워졌다.
다음 코드에 대해서 가상클래스에 대해 배워보자.
<!-- div>(p>lorem)*2 -->
<div>
<p id="clickme">
Placeat temporibus accusamus aspernatur voluptates nobis quam ducimus eos totam magni?
Optio placeat nam aperiam cupiditate facilis numquam voluptas itaque repudiandae eveniet!</p>
<p id="hoverme">Velit doloremque cumque, est porro aliquid illo quod numquam, atque, ratione a in suscipit nulla nemo vitae odit ipsa tempore autem ipsam ullam labore itaque maiores. Dignissimos animi labore soluta.</p>
<p>
<a id="mylink" href="http://www.innerbody.com/htm/body.html">Placeat temporibus accusamus aspernatur voluptates nobis quam ducimus eos totam magni?</a>
</p>
</div>
가상클래스(pseudo-class) 선택자
data:image/s3,"s3://crabby-images/bbdfc/bbdfc98d235f72450b5a94b02ad75b350a72168c" alt=""
data:image/s3,"s3://crabby-images/d66c6/d66c6ef9de461b3f56a16561ef813d16c6532387" alt=""
클릭할 경우 배경색이 올리브색으로 바뀐다.
data:image/s3,"s3://crabby-images/a59f9/a59f9975af489cf0a95bce4a80d2a4bd845b7473" alt=""
커서를 가져다 댈 경우 배경색이 바뀐다.
data:image/s3,"s3://crabby-images/c7cd3/c7cd3f964b2f1ebdc67b9f3f818dc4cb216de3bb" alt=""
data:image/s3,"s3://crabby-images/9378b/9378bae6060ae201b765160cac0e6e1d53db8549" alt=""
data:image/s3,"s3://crabby-images/62572/62572cadcad3a42ec5f18e0cda70166add8a4d2a" alt=""
커서를 가져다 대면 연두색으로 바뀌고, 클릭시 노란색으로 바뀌며, 이미 들어갔다 나온 코드는 분홍색이 된다. 방문전에는 아쿠아색이나, 이미 방문한 경험이 있어 뜨지 않는다. ㅠㅠ
다음코드에 대해서 가상클래스 선택자에 대해 더 자세히 알아보자.
<div class="wrapper">
<input type="text" name="nickname" id="nickname">
<br>
<input type="checkbox" name="fruit" id="apple"><label for="apple">사과</label>
<input type="checkbox" name="fruit" id="pear"><label for="pear">배</label>
<input type="checkbox" name="fruit" id="peach"><label for="peach">복숭아</label>
</div>
가상클래스 선택자
data:image/s3,"s3://crabby-images/2a8c1/2a8c1d20a4e53ee59b8a10dc205c72708b9f9a7a" alt=""
data:image/s3,"s3://crabby-images/20e6c/20e6c9ce2a7fea4808284d5c2640cda3ee45263f" alt=""
data:image/s3,"s3://crabby-images/6fda2/6fda2ed04f1a9e088f8b513126d8c97d03d99bf5" alt=""
data:image/s3,"s3://crabby-images/56d39/56d3958767cf35590bfeeecea781e942547326fb" alt=""
체크하는 것에 대해서 커지는 것을 확인할 수 있다. (체크박스와 라벨 모두)
<div id="container">
<p>CSS1</p>
<p>CSS2</p>
<p>CSS3</p>
<p>CSS4</p>
<p>CSS5</p>
<pre>CSS6</pre>
</div>
위치관련 가상클래스 선택자
data:image/s3,"s3://crabby-images/55113/5511327b001c7a59754d010ca9a7f64fc93edb1d" alt=""
data:image/s3,"s3://crabby-images/a5d09/a5d096127b136fff5a3841311e3ab834892ea1d6" alt=""
data:image/s3,"s3://crabby-images/e70d1/e70d1268c87bba1c00abb7b325df5bf4b96651c5" alt=""
data:image/s3,"s3://crabby-images/3ec4c/3ec4c3a5f3252db9123df5b6d919b9a472d7db3e" alt=""
첫번째와 마지막 container에 대해서 처리 가능.
짝홀수표현 n의 배수로 처리 가능
data:image/s3,"s3://crabby-images/62193/621935a6dd3a72518dc1fd713ab0ba3de4986de7" alt=""
data:image/s3,"s3://crabby-images/ef928/ef928daeccde1193add203e72a81b7635d90b4f7" alt=""
홀수번째에 대해서 아쿠아색으로 변경됨. (짝수번째도 당연히 가능하다.
위치/타입관련 가상클래스 선택자
data:image/s3,"s3://crabby-images/9d8d8/9d8d838556532462433995af4fd3f42798d90b73" alt=""
data:image/s3,"s3://crabby-images/914c3/914c36abe1b416a2bbd26f03f7e2d738c50c1f96" alt=""
data:image/s3,"s3://crabby-images/76037/760376be3df08fd4ca1fe6b88d1c6df6ed23f604" alt=""
data:image/s3,"s3://crabby-images/f792b/f792b6372c164bd2d4c0bd69f9c2590e58becc42" alt=""
정해진 순서에 대해서 지정된 색으로 변경되었다.
<!-- div.box>p{안녕$}*5 -->
<div class="box">
<p>안녕1</p>
<p>안녕2</p>
<p>안녕3</p>
<p>안녕4</p>
<p>안녕5</p>
</div>
부정선택자 : not(selector)
data:image/s3,"s3://crabby-images/a8973/a8973e136de00da964f03c16f054d5cfd247671e" alt=""
data:image/s3,"s3://crabby-images/0a1fd/0a1fdf367c659f04e16ef622a943e5d2eb1b7432" alt=""
4번째만 빼고 배경색이 적용되었다.
루트선택자 - 단독으로 사용
data:image/s3,"s3://crabby-images/b5241/b524142248be405b8aef96a124f7534681afedf2" alt=""
data:image/s3,"s3://crabby-images/ebd9e/ebd9e69f709c8be0b3254bdfc99a68c0709326af" alt=""
모든요소 선택된 것과 같다 (* 아스타리카 쓰는것과 같음)
<!-- div>(p>lorem)*3 -->
<div id="articles">
<p>Lorem ipsum dolor sit, amet consectetur adipisicing elit. Non, aliquid quos aperiam magni quisquam perferendis quae aspernatur dolore vitae recusandae assumenda repellendus voluptatibus obcaecati, quod unde suscipit ad! Ipsa, vel.</p>
<p>Eius nostrum quod dolorem fugit architecto in mollitia error ipsum rem possimus perspiciatis dolore id ipsam adipisci animi facilis labore, dolorum voluptate officiis aperiam laboriosam unde fugiat eveniet. Magnam, ab!</p>
<p>Reprehenderit omnis enim architecto voluptatem! Nihil qui in, corrupti officiis doloribus aut sunt natus sint incidunt nisi doloremque, eligendi, dolore labore. Iure, dignissimos odit delectus animi tempore neque quas veritatis.</p>
</div>
가상요소 pseudo-element 선택자
data:image/s3,"s3://crabby-images/1f192/1f192a447aada61921d134dc8730241cd65c7392" alt=""
data:image/s3,"s3://crabby-images/c29ba/c29bad89ff2dd07079efb877bef45c979d7a73b7" alt=""
data:image/s3,"s3://crabby-images/13b68/13b68401ca603f42e2c9c26aff76301f93e95053" alt=""
첫번째 글자가 2배로 커진 것을 확인할 수 있다.
첫번째와 마지막에 폭죽, 깃발이 붙은 것을 확인할 수 있다.
드래그시 지정된 색으로 나오는 것을 확인할 수 있다.
선택자 우선순위
(우선순위높음)
!important
inline속성
a : #id
b: .class, attribute, pseudo-class
c: tag,pseudo-element
(우선순위낮음)
CSS 선택자는 점수를 매겨 합산점수가 높은 순으로 우선순위를 줘서 스타일을 먹인다.
data:image/s3,"s3://crabby-images/c3381/c338150ebed84e045ba588e3147982bda2bf6753" alt=""
사진 설명을 입력하세요.
이렇게 점수를 매긴다고 한다.
이 점수는 '명시도'라고 부른다.