JavaScript_32.DOM(수업 내용 정리)

🙋🏻‍♀️·2022년 5월 1일
0

32. DOM(수업 내용 정리)


32-1. DOM (Document Object Model)

DOM(돔)이란 웹페이지의 HTML을 계층화시켜 트리구조로 만든 객체(Object) 모델입니다. JavaScript는 이 model로 웹 페이지에 접근하고, 페이지를 수정할 수 있습니다. DOM은 HTML인 웹페이지와 스크립팅언어(JavaScript)를 서로 잇는 역할입니다.

그래서 JavaScript는 어떻게 HTML에 접근할 수 있다는 말일까요? 바로 document라는 전역객체를 통해 접근할 수 있습니다. JavaScript의 document 객체는 DOM 구조를 접근하는 관문이며, document 객체는 HTML 문서를 나타낸다고 말할 수 있습니다.



32-2. 왜 HTML을 접근해야 할까?

개발자도구 시간에 함께 보았던 마켓컬리의 사이트를 보면 카테고리 목록을 HTML에 "육류, 채소 등등.." 직접 작성하지 않았었죠. API를 통해 서버에서 카테고리 목록의 데이터를 가져왔습니다.

document객체는 DOM트리의 root node에 접근하게 해줍니다. document객체로 요소(element)에 접근하듯이 요소의 속성(attribute)에도 접근할 수 있습니다. 그렇게 class, id도 추가하고 style도 수정할 수 있습니다. 요소의 내용(content)는 innerHTML으로 접근하고 수정할 수 있습니다.

document.body.innerHTML = '내용 다 바꿈';

위는 body태그 내부에 있는 것을 '내용 다 바꿈'이라는 텍스트로 바꾼 것입니다. body태그내에 엄청나게 많은 요소가 있더라도 innerHTML을 사용하면 내용이 전부 교체됩니다. 특정 element를 접근하고 싶을 때는 어떻게 해야할까요? tag, class, id와 같은 css selector로 접근 가능합니다.

let blueElement = document.querySelector('.blue');
blueElement.style.backgroundColor = 'blue';

위와 같이 스타일도 수정할 수 있는데 css에서 사용했던 property 명과는 조금 달라보입니다.background-color대신 backgroundColor으로 접근한것에 주목해주세요. JavaScript에서 style 수정할 때 hypen(-)은 사용할 수 없습니다. 객체(Object)에서 프로퍼티 이름에 hypen(-)을 사용할 수 없던 이유와 같습니다. 그러므로 style의 프로퍼티에 접근하고 싶을 때 camelCase로 바꾸시면 됩니다. element를 생성할 수도 있습니다.

.createElement (tagName) 함수를 사용하면 요소(element)를 만들 수 있습니다. 위의 함수는 요소를 만들기만 할 뿐, 아직 HTML의 어디에 들어가야 할지 지정해준 것이 아니죠. 만든 후에는 어딘가의 element에 append시켜줘야 합니다. innerHTML는 내용을 전부 대체 시켰다면 appendChild함수는 요소의 뒤쪽에 붙여줍니다.





✍️Assignment

index.js에 아래의 내용을 구현해주세요.

p 태그를 생성하고 (hint: createElement),
• 해당 요소에 dom 이라는 class 이름을 주고 (hint: className)
• 해당 요소에 "DOM" 이라는 텍스트를 넣어서 (hint: innerHTML)
h1요소 내부에 추가 (hint: appendChild)

function addElement() {
  let h1 = document.getElementsByClassName('h1');
 
  let addElement = document.createElement('p');

  addElement.className = 'dom';
  addElement.innerHTML = 'DOM';

  h1.appendChild(addElement);
 
}
addElement();

0개의 댓글