data:image/s3,"s3://crabby-images/5e053/5e05317eb10f3438ffe19793de24d4458bf0676f" alt="바닐라 JS) 10. CSS"
1. 색깔 확인하기
- index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> <!--style.css 적용하기--> <title>Hello From HTML</title> </head> <body> <div class="hello"> <h1>Hello!</h1> </div> <div class="hello"> <h1>Hello!</h1> </div> <div class="hello"> <h1>Hello!</h1> </div> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
- app.js
const h1 = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 function handleTilteClick(){ // 클릭시 이벤트 console.log(h1.style.color); h1.style.color = "blue"; console.log(h1.style.color); } h1.addEventListener("click", handleTilteClick);
data:image/s3,"s3://crabby-images/0bb3b/0bb3b9e3f59900d2a4ecbec961db6e17283f34a9" alt="notion image"
2. 가정법 사용하기
- app.js
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { // 클릭 시 이벤트 if (h1.style.color === "blue") { h1.style.color = "tomato"; } else { h1.style.color = "blue"; } } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/e7d09/e7d093e3040baef370b5f84b24bd7702839c14e3" alt="notion image"
data:image/s3,"s3://crabby-images/7497c/7497c72d31cc2809eb8c5b4325dff94fb320e5d9" alt="notion image"
data:image/s3,"s3://crabby-images/b3a6b/b3a6b5e25bfe67e2f80d27667564c2ba2d8bbdfb" alt="notion image"
3. 현재 상태 저장하기
- app.js
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { // 클릭 시 이벤트 const currentColor = h1.style.color; let newColor; if (currentColor === "blue") { newColor = "tomato"; } else { newColor = "blue"; } h1.style.color = newColor; } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/92b5a/92b5a90cf1cf69ae4d328ef0d4cabc1cbcee0039" alt="notion image"
data:image/s3,"s3://crabby-images/d6983/d69835398ef6ab1be557d44e1606ce19d97e2ffb" alt="notion image"
data:image/s3,"s3://crabby-images/d06eb/d06ebd48220e1393342f57147e67af9721119559" alt="notion image"
4. CSS 파일에서 적용하기
- className 사용하기
- app.js
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { h1.className = "active"; } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
body { background-color: beige; } h1 { color: cornflowerblue; } .active{ color: tomato; }
data:image/s3,"s3://crabby-images/62771/62771bd65003afd65c4e3ac8ededa08d942ee568" alt="notion image"
data:image/s3,"s3://crabby-images/0d4b6/0d4b621ed134597582737620dcda09ab03e63976" alt="notion image"
- 가정법 사용하기
- app.js
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { if(h1.className === "active"){ h1.className = ""; } else { h1.className = "active"; } } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/40c2b/40c2bb7914677478564e256fba0602ac7b80829d" alt="notion image"
data:image/s3,"s3://crabby-images/eaa5e/eaa5ea690cff75c795d85d74f1acab43acbcc3f5" alt="notion image"
transition
사용하기- 요소의 속성 값이 변화할 때 애니메이션 효과를 부드럽게 적용하는 데 사용
- 속성 값이 변화할 때 즉시가 아니라, 일정 시간 동안 부드럽게 변경되게 함
body { background-color: beige; } h1 { color: cornflowerblue; transition: color .5s ease-in-out; } .active{ color: tomato; }
data:image/s3,"s3://crabby-images/ac964/ac9647ddaa73e88c616ff5dc3e777181c8f2afda" alt="notion image"
data:image/s3,"s3://crabby-images/9d725/9d7251259d5ef014bf68a30f911cb8d9402990e4" alt="notion image"
- 오류의 위험 줄이기
- 정확한 변수명 사용하기
- 변수를 선언해서 사용하기
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { const clickedClass = "clicked"; if(h1.className === clickedClass){ h1.className = ""; } else { h1.className = clickedClass; } } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/093d3/093d31f1aa2434010d89e726272cdd3ab14c0687" alt="notion image"
data:image/s3,"s3://crabby-images/ee81c/ee81c65d78ca509018ba9305e1841a35abf7397b" alt="notion image"
- classList 사용하기
- class들의 목록으로 작업할 수 있게 허용해 줌
- className은 이전 class에 상관없이 다 교체해버림
- contains : 확인하기
- index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="style.css"> <!--style.css 적용하기--> <title>Hello From HTML</title> </head> <body> <div class="hello"> <h1 class="hi">Hello!</h1> </div> <div class="hello"> <h1>Hello!</h1> </div> <div class="hello"> <h1>Hello!</h1> </div> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { const clickedClass = "clicked"; if(h1.classList.contains(clickedClass)){ // clicked가 포함되어있는지 확인 h1.className = ""; } else { h1.className = clickedClass; } } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/8403e/8403e0a3b871f8c16ab7b4ae1fed5022e4ad2550" alt="notion image"
data:image/s3,"s3://crabby-images/61fd5/61fd5b3eda381391a27213cd915a35840a64cbf7" alt="notion image"
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { const clickedClass = "clicked"; if (h1.classList.contains(clickedClass)) { // clickedClass가 포함되어 있는지 확인 h1.classList.remove(clickedClass); // clickedClass 제거 } else { h1.classList.add(clickedClass); // clickedClass 추가 } } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/16d56/16d561952665e65c8271021290ed677b20d30b25" alt="notion image"
data:image/s3,"s3://crabby-images/c161e/c161ef91627f96eb3381243bdbb6995e1abb7f08" alt="notion image"
- toggle 이용하기
- classList 내에 clicked classrk 있다면 clicked를 제거해주고 없으면 clicked를 추가해줌
- app.js
const h1 = document.querySelector("div.hello:first-child h1"); // HTML의 요소 가져오기 function handleTitleClick() { h1.classList.toggle("clicked"); } h1.addEventListener("click", handleTitleClick); // 클릭 시 handleTitleClick 함수 호출
data:image/s3,"s3://crabby-images/950a6/950a607783d18d9bda8aa317a707c6cbc609c5d9" alt="notion image"
data:image/s3,"s3://crabby-images/44b81/44b8142225985dae6bcbdae9dabce3aa69ad3e47" alt="notion image"
Share article