JavaScript HTML DOM 요소(노드)
새 HTML 요소 만들기
HTML DOM에 새 요소를 추가하려면 먼저 요소(요소 노드)를 만든 다음 해당 요소를 기존 요소에 추가해야 합니다.
예시
<div id="div1"> <p id="p1">This is a paragraph.</p> <p id="p2">This is another paragraph.</p> </div> <script> var para=document.createElement("p"); var node=document.createTextNode("This is new."); para.appendChild(node); var element=document.getElementById("div1"); element.appendChild(para); </script>
분석 예시:
이 코드는 새로운
요소를 생성합니다.
var para=document.createElement("p");
요소에 텍스트를 추가하려면 먼저 텍스트 노드를 만들어야 합니다. 이 코드는 텍스트 노드를 생성합니다:
var node=document.createTextNode("This is a new paragraph.");
그런 다음 이 텍스트 노드를
요소에 추가해야 합니다.
para.appendChild(node);
마지막으로 기존 요소에 새 요소를 추가해야 합니다.
이 코드는 기존 요소를 찾습니다:
var element=document.getElementById("div1");
다음 코드는 기존 요소 뒤에 새 요소를 추가합니다.
element.appendChild(para);
기존 HTML 요소 삭제
이 코드는 기존 요소에 새 요소를 추가합니다.
예시
<div id="div1"> <p id="p1">This is a paragraph.</p> <p id="p2">This is another paragraph.</p> </div> <script> var parent=document.getElementById("div1"); var child=document.getElementById("p1"); parent.removeChild(child); </script>
예시 분석
이 HTML 문서에는 두 개의 하위 노드(두 개의
요소)가 있는
<div id="div1"> <p id="p1">This is a paragraph.</p> <p id="p2">This is another paragraph.</p> </div>
id="div1"인 요소 찾기:
var parent=document.getElementById("div1");
id="p1"인
요소를 찾습니다.
var child=document.getElementById("p1");
상위 요소에서 하위 요소를 제거합니다.
parent.removeChild(child);
램프 상위 요소를 참조하지 않고 요소를 삭제할 수 있다면 좋을 것 같습니다.
하지만 안타깝습니다. DOM은 삭제해야 하는 요소와 해당 상위 요소를 알아야 합니다.
이는 일반적인 해결 방법입니다. 제거하려는 하위 요소를 찾은 다음 해당 parentNode 속성을 사용하여 상위 요소를 찾습니다.
var child=document.getElementById("p1"); child.parentNode.removeChild(child);
JavaScript HTML DOM - CSS 변경
HTML DOM을 사용하면 JavaScript가 HTML 요소의 스타일을 변경할 수 있습니다.
HTML 스타일 변경
HTML 요소의 스타일을 변경하려면 다음 구문을 사용하세요.
document.getElementById(id).style.property=새 스타일
다음 예에서는
요소의 스타일을 변경합니다.
예시
<html> <body> <p id="p2">Hello World!</p> <script> document.getElementById("p2").style.color="blue"; </script> <p>The paragraph above was changed by a script.</p> </body> </html>
예시
<!DOCTYPE html> <html> <body> <h1 id="id1">My Heading 1</h1> <button type="button" onclick="document.getElementById('id1').style.color='red'"> Click Me!</button> </body> </html>