일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- subquery
- 포트
- 테스트메소드
- application.yml
- docker명령어
- 추후정리
- EC2
- Query
- 검색
- 컨테이너실행
- 서브쿼리
- 메소드명
- 네이티브쿼리
- 외부키
- appspec.yml
- 커밋메세지수정
- 테스트
- foreignkey
- appspec
- WeNews
- 예약
- AuthenticationEntryPoint
- querydsl
- MySQL
- ubuntu
- ㅔㄴ션
- 메세지수정
- 적용우선순위
- 참조키
- 2 > /dev/null
- Today
- Total
제뉴어리의 모든것
다양한 선택자 ( + , ~, first-child, only-child, last-child, nth-child(a)) 본문
CSS 여러가지 선택자
지금까지 포스팅한 선택자 말고도 간간히 사용되는 선택자가 있어서 이것도 한번 정리를 하는게 좋을 듯해서 이번 포스팅에선 나머지 선택자를 알아보겠습니다. CSS를 처음하시는 분들도 가볍게 보시면 됩니다.
저도 잘 외우는 스타일이 아니라서 이렇게 정리를 한번씩 해봅니다. 나중에 기억이 안나면 보면서 하면 되니까 말입니다.
1. A + B
이것은 무슨 연산자 같은 선택자입니다. 이것은 a 태그 옆에 B태그를 선택하라는 선택자입니다.
<style>
div+h1
{ color:green; }
</style>
<body >
<div>
</div>
<h1>안녕하세요</h1>
<div>
<h1>하이요</h1>
</div>
<div>
</div>
<h1> 룰루랄라<h2>
위의 그림을 보면 이해가 갈란가요? 앞에 포스팅 보면 자손,후손에 관한 선택자가 있었는데요. 이것은 자매 관계에 있는 태그 중에 바로 옆에 있는 태그를 선택하라는 선택자입니다. 가운데 h1태그는 div태그 아래에 있기 때문에 적용이 되지 않았죠?
2, A ~ B
자 이것은 물결 무늬 기호가 가운데 있네요. 이것도 역시 A태그 옆에 B태그만 선택하라는 것인데요. + 와 다른점은 이어져 있는 모든 B태그를 선택하는 것입니다.
<style>
div~h1{
color:green;
}
</style>
<body >
<div>
</div>
<h1>안녕하세요</h1>
<h1>어디가세요</h1>
<div>
<h1>하이요</h1>
</div>
<div>
</div>
<h1>룰루랄라<h2>
이것도 실행해 보는 편이 이해가 빠를 듯합니다. div태그 옆에 h1태그의 색깔을 초록색으로 변경을 했는데요. 연속으로 붙어있는 h1태그도 몽땅 선택이 됩니다.
3. :first-child
이것은 일종의 가상 클래스 선택자인데요. 이것은 부모인 태그를 가지고 있는 자식들 중에 첫째를 선택하는 선택자입니다.
<html>
<style>
h1:first-child{
color:green;
}
</style>
<body>
<div>
<h1>어</h1>
<h1>두번째</h1>
<div>
<h1>두단계</h1>
<h1>아이들</h1>
</div>
</div>
<div>
<h1>안녕하세요</h1>
</div>
:first-child가 약간 헷갈리는데 실행을 해 보면 조금 명확하게 알 수 있습니다. 위의 그림을 보면 h1태그가 다들 div태그 안에 있는데요. div가 부모 태그입니다. div안에 다시 div가 들어가도 h1태그 입장에서는 부모만 바라보고 선택되게 됩니다.
4. :only-child
이번에는 only-child입니다. child를 유념해서 보면 이것도 그렇게 어렵지 않은 선택자입니다. 누군가의 자식이지만 외동을 의미합니다. 형제가 없는 요소를 선택하는 것입니다.
<style>
h1:only-child{
color:green;
}
</style>
<body>
<div>
<h1>어</h1>
<h1>두번째</h1>
<h1>세번째</h1>
<div>
<h1>두단계</h1>
<h1>아이들</h1>
</div>
</div>
<div>
<h1>안녕하세요</h1>
</div>
<h1>네번째</h1>
예제가 너무 장황한데요. h1태그를 기준으로 형제가 없는 h1태그는 "안녕하세요"의 h1태그 밖에 없습니다. "네번째" h1 태그는 body 태그라는 부모가 있고 div태그라는 여러 형제가 있습니다. 나머지 h1태그는 h1태그들이 형제로 존재하고 있습니다.
5. :last-child
이것은 위의 first-child와는 반대되는 선택자입니다. 이것도 한번 실행을 해보면 쉽게 이해가 갈 듯합니다.
<style>
h1:last-child{
color:green;
}
</style>
<body>
<div>
<h1>어</h1>
<h1>두번째</h1>
<h1>세번째</h1>
<div>
<h1>두단계</h1>
<h1>아이들</h1>
</div>
</div>
<div>
<h1>안녕하세요</h1>
</div>
<h1>네번째</h1>
h1태그 중에 부모밑에 혼자 있는 태그는 첫째이기도 하고 마지막이기도 해서 초록색으로 변경되었습니다. "세번째"를 감싸고 있는 h1 태그는 왜 변하지 않았을 까요? 이것은 <div>태그가 형제로서 제일 마지막이기 때문에 h1태그가 마지막이 되지 않은 것입니다.
6. :nth-child(a)
이 선택자는 딱 필이 오지 않습니까? 보통 각자 분할 계산할 때 "n분의 1"이라는 말 자주 사용하죠? 딱 유사한 선택자입니다. child 들어간 선택자는 우선 부모가 기준이 된다는 것은 다른 child가 들어간 선택자를 보면 쉽게 유추가 됩니다.
<style>
#aaa>h1:nth-child(2){
color:green;
}
</style>
<body>
<div id="aaa">
<h2>어</h2>
<h1>두번째</h1>
<h3>세번째</h3>
<div>
<h1>두단계</h1>
<h1>아이들</h1>
</div>
</div>
<div>
<h1>안녕하세요</h1>
</div>
<h1>네번째</h1>
이번에는 약간 응용을 해봤는데요. 자손 선택자와 함께 사용을 해봤습니다. 두번째 자손이면서 h1 태그에게 적용되는 것이 보이시죠? 여기서 #aaa>를 빼고 속성을 준다면 "두번째"와 "아이들"이 초록색으로 변하게 됩니다.
이런 선택자는 사실 코딩에서 사용을 잘 안할 듯한데 제가 워드프레스 테마를 만들면서 id나 클래스 선택자없이 유동적으로 css를 줘야할 경우가 생겨서 이런 선택자들이 제법 필요하더군요. 혹시나 css를 처음하시는 분들은 위의 선택자들은 높은 빈도로 사용을 하는 선택자는 아니니까 지금은 이런 선택자가 있구나 정도만 기억해도 될 듯합니다.
출처 : https://m.blog.naver.com/PostView.naver?isHttpsRedirect=true&blogId=kkrdiamond77&logNo=221148269517
'css' 카테고리의 다른 글
perspective 주의점. (0) | 2022.05.14 |
---|---|
여러가지 연산자 (>), (추후 업데이트) (0) | 2022.05.14 |
CSS 선택자의 종류 (0) | 2021.03.31 |
간단한 모바일웹 채팅 UI (리스트) HTML 코드 (0) | 2021.03.23 |
[자바스크립트] 채팅 구현 코드 (프론트) (0) | 2021.03.23 |