일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 알고리즘 연습
- js
- django rest framework
- Git
- django widget
- AWS
- django ORM
- HTML
- DRF
- CSS
- javascript
- c++
- 파이썬
- Django
- form
- 장고
- API
- java
- 파이썬 알고리즘
- Baekjoon
- 알고리즘 풀이
- react
- 알고리즘
- Algorithm
- web
- 알고리즘 문제
- MAC
- PYTHON
- es6
- 백준
Archives
- Today
- Total
수학과의 좌충우돌 프로그래밍
[CSS] checkbox 만들기 본문
로그인 페이지를 구현하는 중, 로그인 유지 기능을 만들게 되었습니다. 로그인 유지를 할지 말지 checkbox로 선택을 받으려 했습니다. 하지만 그러기에 checkbox 의 디자인이 너무 이쁘지 않아서 새롭게 디자인 하고자 했습니다.
현재 checkbox 와 label은 다음과 같습니다.
<div class="keep_login_container">
<input id="keep_login_checkbox" type="checkbox" name="keep_login" value="TRUE">
<label for="keep_login_checkbox">keep login</label>
</div>
먼저 현재의 checkbox가 보이지 않게 해주었습니다. 해당 위치에 다른 checkbox 를 만들어줄 것이기 때문에 공간도 차지하지 않도록 해주었습니다.
input[type=checkbox] {
display: none;
}
다음으로는 label
에 대한 속성을 추가해주었습니다. 옆에 checkbox가 들어갈 공간을 주기 위해서 좌측 패딩 값을 주었습니다.
input[type=checkbox] + label{
cursor: pointer;
padding-left:25px;
}
이제 before
속성을 이용하여 label
전에 안보이는 원래의 checkbox 에 css 를 주었습니다. 내용은 비어있게 끔 하고 전체적인 크기, 색, 테두리 굴곡, 음영 등을 추가해주었습니다. 그리고 위치를 잡기 위해서 position
을 절대적으로 왼쪽에 밀착시켰습니다. 이 경우, 최상단인 body
를 기준으로 적용되기 때문에 부모 div
에 position
도 바꿔주었습니다.
input[type=checkbox] + label:before {
content: "";
width: 20px;
height: 20px;
margin-right: 10px;
position: absolute;
left: 0;
background-color: #f7f7f7;
border-radius: 2px;
box-shadow: inset 0px 1px 1px 0px rgba(0, 0, 0, .3), 0px 1px 0px 0px rgba(255, 255, 255, .8);
}
.keep_login_container {
position: relative;
}
마지막으로 checkbox
를 check 했을 때, 체크 표시가 나타나고 배경색이 바뀌도록 해주었습니다.
input[type=checkbox]:checked + label:before{
content: "\2714";
text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
font-size: 18px;
font-weight:600;
color: #fff;
background:#2f87c1;
text-align: center;
}
최종적인 css
는 다음과 같습니다.
.keep_login_container {
position: relative;
}
input[type=checkbox] {
display: none;
}
input[type=checkbox] + label{
cursor: pointer;
padding-left:25px;
}
input[type=checkbox] + label:before {
content: "";
width: 20px;
height: 20px;
margin-right: 10px;
position: absolute;
left: 0;
background-color: #f7f7f7;
border-radius: 2px;
box-shadow: inset 0px 1px 1px 0px rgba(0, 0, 0, .3), 0px 1px 0px 0px rgba(255, 255, 255, .8);
}
input[type=checkbox]:checked + label:before{
content: "\2714";
text-shadow: 1px 1px 1px rgba(0, 0, 0, .2);
font-size: 18px;
font-weight:600;
color: #fff;
background:#2f87c1;
text-align: center;
}
'웹프로그래밍 > html,css' 카테고리의 다른 글
[html]input의 필수값을 지정하는 required (1) | 2019.06.25 |
---|---|
[html] form 안에 button이 있으면? (4) | 2019.06.02 |
[css] div에 이미지 꽉 채우는 방법 (0) | 2019.03.31 |
[css] css 선택자(selector) 의 종류와 예시 (3) | 2019.03.24 |
[html] vs code extension, Highlight Matching Tag (0) | 2019.02.25 |
Comments