insertBefore(newElement, referenceElement) : 두번째 인자로 전달한 엘리먼트 앞에 새로운 엘리먼트 추가
노드를 추가하기 위해서는 추가할 엘리먼트를 생성해야하는데 이것은 document 객체의 기능임
document.createElement(tagname) : 엘리먼트 노드 생성
document.createTextNode(data) : 텍스트 노드 생성
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title></title>
</head>
<body>
<ul id="target">
<li>HTML</li>
<li>CSS</li>
</ul>
<input type="button" onclick="fn_appendChild();" value="appendChild()">
<input type="button" onclick="fn_insertBefore();" value="insertBefore()">
<script>
function fn_appendChild() {
var target = document.getElementById('target');
// li 엘리먼트 노드 생성
var li = document.createElement('li');
// 텍스트 노드 생성
var text = document.createTextNode('JavaScript');
// li노드의 텍스트노드 삽입
li.appendChild(text);
// ul에 하위 자식으로 마지막에 새로 만든 li노드 추가
target.appendChild(li);
}
function fn_insertBefore() {
var target = document.getElementById('target');
var li = document.createElement('li');
var text = document.createTextNode('JavaScript');
li.appendChild(text);
// ul에 하위 자식으로 첫번째 자식의 앞에 새로 만든 li노드 추가
target.insertBefore(li, target.firstChild);
}
</script>
</body>
</html>
노드 제거
removeChild(child) : 메소드는 삭제 대상의 부모 노드의 객체의 것을 실행해야 함