data:image/s3,"s3://crabby-images/2e5e1/2e5e1a1a04d9e400ebb42f17cab38405e11e73b3" alt="바닐라 JS) 8. Document"
1. Document Object Model (DOM)
- HTML이나 XML 문서의 구조를 프로그래밍적으로 표현한 것
- 구조는 문서의 각 요소를 객체로 표현
- JavaScript같은 프로그래밍 언어로 문서의 내용이나 구조를 동적으로 수정 가능
2. Document Object
- DOM의 최상위 객체
- 현재 웹 페이지
- 웹 페이지에서 사용하는 모든 HTML 요소들은 이 다큐먼트 오브젝트의 하위에 위치
- JavaScript에서
document
객체를 사용하여 HTML 요소를 조작하거나, 새로 추가하거나, 삭제하는 등의 작업을 할 수 있음 - 요소 선택
document.getElementById
,document.querySelector
등- 특정 HTML 요소를 선택 가능
- 내용 변경
- 선택된 요소의 텍스트나 HTML을 수정 가능
- 이벤트 처리
document.addEventListener
- 특정 이벤트에 대한 처리기를 추가 가능
- 새 요소 추가
document.createElement
- 새로운 HTML 요소를 만들고, 이를 문서에 추가 가능
3. Document
- 브라우저에 이미 존재하는 객체(Object)
- HTML에 JavaScript가 자동으로 연결되어 있음
- 콘솔 창에서
document
입력한 결과
data:image/s3,"s3://crabby-images/05311/05311e3c4974785cdb00592fdb55fe9bc2fa363e" alt="notion image"
- index.html 코드와 동일
data:image/s3,"s3://crabby-images/a482f/a482f3705b4ed67c4d81c47cd1e43b52da386314" alt="notion image"
- 콘솔창에 document의 목록보기
- 정말 많은 정보가 들어있는 객체임
console.dir(document);
data:image/s3,"s3://crabby-images/54963/54963eae07176e7e10ea76e1d051328c914062c2" alt="notion image"
- index.html 코드에 입력된 title과 동일한 결과가 있음
- document가 JavaScript의 관점으로 HTML을 보여줌
data:image/s3,"s3://crabby-images/38175/381750cca7d29291659cf467f47a160fec8e756b" alt="notion image"
data:image/s3,"s3://crabby-images/c65df/c65df380d830642140ae49dbbf070b2a664a9aef" alt="notion image"
- JavaScript는 HTML에 접근하고 읽을 수 있음
- 브라우저가 HTML 정보가 많이 들어있는 DOCUMENT라는 객체를 전달해줌
document.title
data:image/s3,"s3://crabby-images/fee87/fee87a78c8e50aa0195b50e628de90a1974d62cf" alt="notion image"
- JavaScript는 HTML에 접근하고 수정할 수 있음
- 새로고침하면 원래대로 돌아가고 코드 자체에는 영향을 주지 않음
document.title = "Hi"
data:image/s3,"s3://crabby-images/8d2f8/8d2f85547232d73c6f23d31e328314c200c60e10" alt="notion image"
data:image/s3,"s3://crabby-images/e2c4b/e2c4b48cd5ea85933782822961a6ab75ce494eac" alt="notion image"
- JavaScript로 HTML을 변경했음
- 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> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
document.title = "Hello! From JS"
data:image/s3,"s3://crabby-images/3fdbd/3fdbdf20b37a60774e3161689585c9f30336d9b8" alt="notion image"
- id를 이용하기
<!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> <h1 id="title">Grab me!</h1> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
data:image/s3,"s3://crabby-images/1c4f7/1c4f737570ad3abfdb06c42facc5f3f5db4c8d94" alt="notion image"
data:image/s3,"s3://crabby-images/cceaf/cceafff00a7459f4764717021071996fe1c1ad19" alt="notion image"
const title = document.getElementById("title"); console.log(title);
data:image/s3,"s3://crabby-images/04c79/04c7986e5595c8174ab2c2913c77168fe79f98dc" alt="notion image"
autofocus
- 페이지가 로드될 때 특정 요소에 자동으로 포커스를 맞추는 역할
- 웹 페이지가 열리거나 새로고침될 때,
autofocus
속성이 지정된 요소가 자동으로 선택되어 사용자 입력을 받을 준비가 된 상태
<body> <h1 autofocus id="title">Grab me!</h1> <script src="app.js"></script> <!--app.js 적용하기--> </body>
data:image/s3,"s3://crabby-images/29ea8/29ea86f187850ce8bf82e64358edf9389ec9808f" alt="notion image"
data:image/s3,"s3://crabby-images/a4d5f/a4d5f2bd078c8eb2f101ccfd1a521d5184d90493" alt="notion image"
data:image/s3,"s3://crabby-images/bf7a9/bf7a9d1d35a642d93ce12a0814a9c6056b91b37f" alt="notion image"
<!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> <h1 autofocus class="now" id="title">Grab me!</h1> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
data:image/s3,"s3://crabby-images/2d3a8/2d3a801d199ac2762099b4c437b4d94a06c4f39f" alt="notion image"
data:image/s3,"s3://crabby-images/8afd4/8afd4c9cc71d99f5ba525f2043df93b29194bf79" alt="notion image"
- inner text
data:image/s3,"s3://crabby-images/96059/96059a58bb8df90a6a4ac0afeb5342c38fe69a78" alt="notion image"
- JavaScript에 의해 HTML 변경하기
- 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> <h1 id="title">Grab me!</h1> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
const title = document.getElementById("title"); title.innerText = "Get you";
data:image/s3,"s3://crabby-images/01e81/01e81459ecf2290f7aad73db4d4a6518a6b0b83b" alt="notion image"
- html에 있는 요소와 동일한 이름의 요소로만 찾을 수 있음 아니면 오류남
- ClassName 이용하기
- 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> <h1 class="hello">Hello!</h1> <h1 class="hello">Hello!</h1> <h1 class="hello">Hello!</h1> <h1 class="hello">Hello!</h1> <h1 class="hello">Hello!</h1> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
const hellos = document.getElementsByClassName("hello"); console.log(hellos);
data:image/s3,"s3://crabby-images/14282/14282058a1ac29a85084f10c16f5c0315a11ac14" alt="notion image"
- tagName 이용하기
- anchor, div, section, button 등
- 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> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
const title = document.getElementsByTagName("h1"); console.log(title);
data:image/s3,"s3://crabby-images/e5a8d/e5a8df4a828526d956dc53bd6e4b1937796db49e" alt="notion image"
- querySelector 이용하기
- CSS 처럼 쓸 수 있음
- hello라는 class를 찾고 그 안에 있는 h1 가져오기
- app.js
const title = document.querySelector(".hello h1"); console.log(title);
data:image/s3,"s3://crabby-images/b1581/b158177e2e80de61da1cb3d2af8a2076570ee3ad" alt="notion image"
- 없으면 null이고 값을 찾으면 첫번째만 반환함
- 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>
const title = document.querySelectorAll(".hello h1"); console.log(title);
data:image/s3,"s3://crabby-images/cfa40/cfa407cab398ebd54914eac1082545bc8158bcc0" alt="notion image"
const title = document.querySelector(".hello h1:first-child"); console.log(title);
data:image/s3,"s3://crabby-images/7bb07/7bb07601b6fc228cad34c576409f2cdb1121b7cf" alt="notion image"
- querySelector와 getElementById는 같은 결과값을 반환함
- getElementById는 id 하위 요소(form 등)를 이용할 수 없음
<!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 id="hello"> <h1>Hello!</h1> </div><div id="hello"> <h1>Hello!</h1> </div><div id="hello"> <h1>Hello!</h1> </div> <script src="app.js"></script> <!--app.js 적용하기--> </body> </html>
const title1 = document.querySelector("#hello"); // # = id const title2 = document.getElementById("hello"); console.log(title1); console.log(title2);
data:image/s3,"s3://crabby-images/f53d8/f53d84cdbd8d95108fc5a99ad446cde596f97d80" alt="notion image"
Share article