제로하우스
[TIL][DOM] 04 DOM CRUD 본문
Create
- createElement를 사용하여 새로운 element를 만들 수 있다.
// div element를 만든다
document.createElement('div')
Append
- append를 사용해 부모 노드에 자식 노드를 추가할 수 있다.
// 생성한 div를 트리 구조와 연결한다
const exampleDiv = document.createElement('div')
document.body.append(exampleDiv)
- appendChild 메서드는
append
메서드와는 다르게 오직 Node 객체만 받을 수 있으며, 한 번에 오직 하나의 노드만 추가할 수 있다.
Read
- querySelector의 첫 번째 엘리먼트만을 가져오며, selector로는 아래 3가지를 가장 많이 사용한다.
// 1. HTML 태그
const example = document.querySelector("div")
// 2. id
const example = document.querySelector("#example")
// 3. class
const example = document.querySelector(".example")
- querySelectorAll은 여러 개의 엘리먼트를 한 번에 가져오기 위해 사용한다.
const examples = document.querySelectorAll('.example')
- 오래된 방식 중 getElementById라는 메서드가 있으며, 하나의 요소만 가져온다.
const example = document.getElementById('example')
Update
- textContent을 사용하면 비어있는 엘리먼트에 문자열을 입력할 수 있다.
const exampleDiv = document.querySelector('#example-div') // <div></div>
exampleDiv.textContent = 'This is an exmple div tag.'
- classList.add를 이용해 엘리먼트에 클래스를 추가할 수 있다.
exampleDiv.classList.add('exampleDiv')
- :ballot_box_with_check:
setAttribute
라는 메소드를 사용하여 엘리먼트에 class, id 외에 다른 attribute를 추가할 수 있다.
Delete
- remove를 사용하면 위치를 알고 있는 엘리먼트를 삭제할 수 있다.
const container = document.querySelector('#container')
const exampleDiv = document.createElement('div')
container.append(exampleDiv)
exampleDiv.remove() // 엘리먼트를 삭제할 수 있다.
innterHTML
을 이용하면 여러 개의 자식 엘리먼트를 간단히 지울 수 있다.
// id가 container인 엘리먼트 아래의 모든 엘리먼트를 지운다.
document.querySelector('#container').innterHTML = ''
- :warning: 단, 위 메서드는 보안 상 몇 가지 문제점을 가지고 있으며, 이는 removeChild 메소드로 대신할 수 있다.
const container = document.querySelector('#container')
while (container.children.length > 1) {
container.removeChild(container.lastChild)
}
- 또는 직접 클래스 이름이 example인 엘리먼트만 찾아서 지울 수도 있다.
const examples = document.querySelectorAll('.example')
examples.forEach(function (example) {
example.remove()
})
// or
for (let example of examples) {
example.remove()
}
Copyright © 2022 Song_Artish
'JavaScript' 카테고리의 다른 글
[TIL][DOM] 06 DOM Dataset (0) | 2022.05.04 |
---|---|
[TIL][DOM] 05 EventListener (0) | 2022.05.04 |
[TIL][DOM] 03 DOM 메서드 (0) | 2022.05.04 |
[TIL][DOM] 02 DOM 객체 (0) | 2022.05.04 |
[TIL][DOM] 01 Documnet Object Model (0) | 2022.05.04 |
Comments