본문 바로가기
  • GDG on campus Ewha Tech Blog
3-2기 스터디/프론트엔드 입문

[7주차] JavaScript (3)

by rovemin 2022. 6. 30.

1. JavaScript는 HTML과 연결되어 있다.

console에 document를 입력하면 작성한 HTML을 가져올 수 있다.

JavaScript에서 HTML을 읽어올 수도 있고, JavaScript에서 HTML을 수정할 수도 있다.

 

2. document는 object이다.

브라우저에서 제공하는 객체중 document 는 JS 에서 HTML 파일을 불러올 수 있도록 도와준다.

 

3. JavaScript에서 HTML 변경하기

=> title element가 "My Day Plan"으로 변경된다.

 

4. JavaScript에서 HTML element를 가져오기

(1) getElementById

<h1 id="title">Grab me!</h1>			//HTML
const title = document.getElementById("title");	//JavaScript
  • HTML의 id로 element를 찾는다.

(2) getElementsByClassName

<h1 class="title">Grab me!</h1>					//HTML
const hellos = document.getElementsByClassName("hello");	//JavaScript

console.log(hellos);

  • class명으로 element를 찾아서 array로 반환한다.

(3) getElementsByTagName

<div class="hello">					//HTML
      <h1>Grab me!</h1>
</div>
const title = document.getElementsByTagName("h1");	//JavaScript
  • 태그명으로 element를 찾아서 array로 반환한다.

(4) querySelector

element를 CSS 방식으로 검색한다.

<div class="hello">					//HTML
      <h1>Grab me! 1</h1>
</div>
<div class="hello">
      <h1>Grab me! 2</h1>
</div>
<div class="hello">
      <h1>Grab me! 3</h1>
</div>
const title = document.querySelector(".hello h1");	//JavaScript

console.log(title);

  • 첫 번째로 검색된 element 하나만 반환

(5) querySelectorAll

element를 CSS 방식으로 검색한다.

<div class="hello">					//HTML
      <h1>Grab me! 1</h1>
</div>
<div class="hello">
      <h1>Grab me! 2</h1>
</div>
<div class="hello">
      <h1>Grab me! 3</h1>
</div>
const title = document.querySelectorAll(".hello h1");	//JavaScript

console.log(title);

  • 조건에 맞는 모든 element 반환

(6) 두 코드는 동일한 일을 한다.

const title = document.querySelector("#hello"); //무엇을 검색하는지 명확하지 않아서 id(#)라고 명시해야 함
const title = document.getElementById("hello");

 

 

(7) querySelector 응용

<div class="hello">					//HTML
      <h1>Grab me!</h1>
</div>
const title = document.querySelector(".hello h1");	//JavaScript

title.innerText = "Hello";

=> 'Grab me!'가 'Hello'로 변경되어 화면에 나타난다.

 

5. Event

const h1 = document.querySelector("div.hello:first-child h1");

function handleTitleClick() {
    h1.style.color = "darkgreen";
}

function handleMouseEnter() {
    h1.innerText = "Mouse is here!";
}

function handleMouseLeave() {
    h1.innerText = "Mouse is gone!";
}

function handleWindowResize() {
    document.body.style.backgroundColor = "salmon";
}

function handleWindowCopy() {
    alert("The text is copied!");
}

function handleWindowOffline() {
    alert("WIFI Error");
}

function handleWindowOnline() {
    alert("WIFI is connected");
}

h1.addEventListener("click", handleTitleClick);
h1.addEventListener("mouseenter", handleMouseEnter);
h1.addEventListener("mouseleave", handleMouseLeave);

window.addEventListener("resize", handleWindowResize);
window.addEventListener("copy", handleWindowCopy);
window.addEventListener("offline", handleWindowOffline);
window.addEventListener("online", handleWindowOnline);

 

6. JavaScript로 CSS 제어하기

const h1 = document.querySelector("div.hello:first-child h1");

function handleTitleClick() {
    const currentColor = h1.style.color;
    let newColor;

    if (currentColor === "darkgreen") {
        newColor = "crimson";
    } else {
        newColor = "darkgreen";
    }
    h1.style.color = newColor;
}

h1.addEventListener("click", handleTitleClick);

 

7. Toggle

<div class="hello">						//HTML
      <h1 class="my-font">Click me!</h1>
</div>
body {								//CSS
    background-color: beige;
}

h1 {
    color: mediumpurple;
}

.clicked {
    color: hotpink;
}

.my-font {
    font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, 
    Ubuntu, Cantarell, 'Open Sans', 'Helvetica Neue', sans-serif;
}
const h1 = document.querySelector("div.hello:first-child h1");	//JavaScript

function handleTitleClick() {
    h1.classList.toggle("clicked");
}

h1.addEventListener("click", handleTitleClick);

 

toggle function은 아래의 코드를 대체할 수 있다.

function handleTitleClick() {
    const clickedClass = "clicked";
    if (h1.classList.contains(clickedClass)) {
        h1.classList.remove(clickedClass);
    } else {
        h1.classList.add(clickedClass);
    }
}
 

'3-2기 스터디 > 프론트엔드 입문' 카테고리의 다른 글

[9주차] JavaScript (5)  (0) 2022.06.30
[8주차] JavaScript (4)  (0) 2022.06.30
[6주차] JavaScript (2)  (0) 2022.06.23
[5주차] JavaScript (1)  (0) 2022.06.23
[4주차] CSS (2)  (0) 2022.06.21

댓글