data:image/s3,"s3://crabby-images/a9111/a911118e0a53a2c04171cb026488d8495cb82618" alt="바닐라 JS) 9. Event Listner"
1. style로 JavaScript 객체 변경하기
- on으로 시작하는 많은 JavaScript Object
data:image/s3,"s3://crabby-images/442c0/442c028252e01768d3f955991707861daaa0ed34" alt="notion image"
- style로 적용해보기
const title = document.querySelector(".hello h1:first-child"); console.log(title);
<!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>
data:image/s3,"s3://crabby-images/fef6d/fef6dcd4325e93abc12eef515e2071fc3a52dde5" alt="notion image"
2. Event가 일어나는 과정
- HTML의 요소 가져오기
- addEventListener로 호출
- Listen 하고 싶은 이벤트 이름 알려주기
- 이벤트 발생
- 호출할 함수에 전달
3. Click Event
- title을 클릭하는 event 듣기
- 클릭 시 이벤트(함수)를 JavaScript에 넘겨주고 사용자가 title을 클릭할 경우 JavaScript가 실행
- app.js
const title = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 function handleTilteClick(){ // 클릭시 이벤트 console.log("title을 클릭했어요!") } title.addEventListener("click", handleTilteClick); // 이벤트 이름, 클릭시 이벤트
data:image/s3,"s3://crabby-images/00d16/00d166bd5d7791a8e9982ff80e14e5bcb296a1ba" alt="notion image"
data:image/s3,"s3://crabby-images/6b3bc/6b3bca97113a54e58c4fecfb5b955d4681712682" alt="notion image"
- app.js
const title = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 function handleTilteClick(){ // 클릭시 이벤트 title.style.color = "blue"; console.log("title을 클릭했어요!") } title.addEventListener("click", handleTilteClick); // 조건 : 클릭, 일어나는 이벤트
data:image/s3,"s3://crabby-images/d6b77/d6b77e9813d0f9b67ff1b1ba629bb5c8b38d78ec" alt="notion image"
data:image/s3,"s3://crabby-images/a0036/a0036b49040a59b0ad80edaccb190b590aa5adac" alt="notion image"
3. Event 찾는 방법
- 구글링하기
- MDN(Mozilla Developer Network)
- Mozilla는 Firefox 웹 브라우저를 개발하는 회사
- Mozilla가 웹 개발자와 디자이너를 위한 다양한 자원과 정보를 제공하기 위해 만든 플랫폼
- MDN Web Docs : MDN의 웹 사이트
- 웹 개발과 관련된 포괄적인 문서화 자료를 제공
- MDN의 핵심 웹 리소스
- HTML, CSS, JavaScript, 웹 API 등 다양한 웹 기술에 대한 정보를 포함
h1 html element mdn
- Web APIs라는 문장이 포함된 페이지 찾기
- Web APIs : JavaScript 관점의 HTML Heading Element란 의미
- 속성 앞에 on이 붙어있는 것이 바로 event listener
- 이벤트 사용시 on은 떼고 사용해야 함
data:image/s3,"s3://crabby-images/99cb7/99cb745d692c5473de643c05185a925fc67d92f9" alt="notion image"
title.addEventListener("click", handleTilteClick); // 조건 : 클릭, 일어나는 이벤트
const title = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 console.dir(title); function handleTilteClick(){ // 클릭시 이벤트 title.style.color = "blue"; console.log("title을 클릭했어요!") } function handleMouseEnter(){ console.log("마우스는 여기 있어요!") } title.addEventListener("click", handleTilteClick); // 조건 : 클릭, 일어나는 이벤트 title.addEventListener("mouseenter", handleMouseEnter);
data:image/s3,"s3://crabby-images/1fac2/1fac21c7a77c16ad60e2b6432dadf7d6697e5af8" alt="notion image"
data:image/s3,"s3://crabby-images/9bd4e/9bd4e6713f9d00e1fb2406f48e0b81b39518c657" alt="notion image"
- 두 가지 이벤트가 동시에 listen 하고 있음
data:image/s3,"s3://crabby-images/04175/041757b63d9bf4bd9ed9c84c18dcb65a1e54288c" alt="notion image"
- Event 추가하기
const title = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 console.dir(title); function handleTilteClick(){ // 클릭시 이벤트 title.style.color = "blue"; console.log("title을 클릭했어요!") } function handleMouseEnter(){ title.innerText = "마우스는 여기 있어요!"; } function handleMouseLeave(){ title.innerText = "마우스는 여기 없어요!"; } title.addEventListener("click", handleTilteClick); // 조건 : 클릭, 일어나는 이벤트 title.addEventListener("mouseenter", handleMouseEnter); title.addEventListener("mouseleave", handleMouseLeave); // removeEventListner를 이용하여 제거할 수도 있음
const title = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 console.dir(title); function handleTilteClick(){ // 클릭시 이벤트 title.style.color = "blue"; console.log("title을 클릭했어요!") } function handleMouseEnter(){ title.innerText = "마우스는 여기 있어요!"; } function handleMouseLeave(){ title.innerText = "마우스는 여기 없어요!"; } title.onclick = handleTilteClick; title.onmouseenter = handleMouseEnter; title.onmouseleave = handleMouseLeave;
data:image/s3,"s3://crabby-images/b39e0/b39e0fe014e27a9c0ff62bbc62b3da96178b402e" alt="notion image"
data:image/s3,"s3://crabby-images/f05f4/f05f44d91f172ef5837826e2922fc63250c1f2d8" alt="notion image"
data:image/s3,"s3://crabby-images/40c2d/40c2dba6f4ecdb1d8c2d8ff00d6f93b2bf5f6f0e" alt="notion image"
data:image/s3,"s3://crabby-images/6bf1b/6bf1b85d4cdcad40caee409db124dbfe56201315" alt="notion image"
- window 사용하기
- 웹 브라우저의 전체 창을 나타내는 JavaScript 객체
- 다양한 브라우저 전역 기능과 속성에 접근 가능
const h1 = document.querySelector(".hello h1:first-child"); // HTML의 요소 가져오기 console.dir(h1); function handleTilteClick(){ // 클릭시 이벤트 h1.style.color = "blue"; console.log("title을 클릭했어요!") } function handleMouseEnter(){ h1.innerText = "마우스는 여기 있어요!"; } function handleMouseLeave(){ h1.innerText = "마우스는 여기 없어요!"; } function handleWindowResize(){ document.body.style.backgroundColor = "tomato"; } h1.addEventListener("click", handleTilteClick); // 조건 : 클릭, 일어나는 이벤트 h1.addEventListener("mouseenter", handleMouseEnter); h1.addEventListener("mouseleave", handleMouseLeave); window.addEventListener("resize", handleWindowResize);
data:image/s3,"s3://crabby-images/66232/66232a7e2ebe7c98169b77cc84a845fb86892abc" alt="notion image"
data:image/s3,"s3://crabby-images/d6f82/d6f8266d9f31b9365ee04732f213fe3ac4d609a0" alt="notion image"
Share article