XML 튜토리얼

XML 홈 XML 소개 XML 사용 방법 XML 트리 XML 구문 XML 요소 XML 속성 XML 네임스페이스 XML 표시 XML HttpRequest XML 파서 XML DOM XML XPath XML XSLT XML XQuery XML XLink XML 유효성 검사기 XML DTD XML 스키마 XML 서버 XML 예제 XML 퀴즈 XML 인증서

XML AJAX

AJAX 소개 AJAX XMLHttp AJAX 요청 AJAX 응답 AJAX XML 파일 AJAX PHP AJAX ASP AJAX 데이터베이스 AJAX 애플리케이션 AJAX 예제

XML DOM

DOM 소개 DOM 노드 DOM 액세스 DOM 노드 정보 DOM 노드 목록 DOM 순회 DOM 탐색 DOM 값 가져오기 DOM 변경 노드 DOM 제거 노드 DOM 교체 노드 DOM 생성 노드 DOM 추가 노드 DOM 복제 노드 DOM 예제

XPath 튜토리얼

XPath 소개 XPath 노드 XPath 구문 XPath 축 XPath 연산자 XPath 예제

XSLT 튜토리얼

XSLT 소개 XSL 언어 XSLT 변환 XSLT <템플릿> XSLT <값> XSLT <각각> XSLT <정렬> XSLT <만약> XSLT <선택> XSLT 적용 클라이언트의 XSLT 서버의 XSLT XSLT XML 편집 XSLT 예

XQuery 튜토리얼

XQuery 소개 XQuery 예제 XQuery FLWOR 엑스쿼리 HTML XQuery 용어 XQuery 구문 XQuery 추가 XQuery 선택 XQuery 함수

XML DTD

DTD 소개 DTD 빌딩 블록 DTD 요소 DTD 속성 DTD 요소 대 속성 DTD 엔터티 DTD 예

XSD 스키마

XSD 소개 XSD 방법 XSD <스키마> XSD 요소 XSD 속성 XSD 제한 사항

XSD 컴플렉스

XSD 요소 XSD 비어 있음 XSD 요소만 XSD 텍스트만 XSD 혼합 XSD 지표 XSD <모든> XSD <모든 속성> XSD 대체 XSD 예

XSD 데이터

XSD 문자열 XSD 날짜 XSD 숫자 XSD 기타 XSD 참조

서비스

XML 서비스 XML WSDL XML SOAP XML RDF XML RSS

참고문헌

DOM 노드 유형 DOM 노드 DOM 노드 목록 DOM NamedNodeMap DOM 문서 DOM 요소 DOM 속성 DOM 텍스트 DOM CDATA DOM 주석 DOM XMLHttpRequest DOM 파서 XSLT 요소 XSLT/XPath 함수

XML DOM - 노드 탐색


노드는 노드 관계를 사용하여 탐색할 수 있습니다.

×

Header


DOM 노드 탐색

노드 간의 관계를 통해 노드 트리의 노드에 액세스하는 것을 종종 "노드 탐색"이라고 합니다.

XML DOM에서 노드 관계는 노드에 대한 속성으로 정의됩니다.

  • 부모 노드
  • 자식 노드
  • 첫 번째 차일드
  • 막내
  • 다음자매
  • 이전 형제자매

다음 이미지는 노드 트리의 일부와 books.xml 에 있는 노드 간의 관계를 보여줍니다 .

노드 트리


DOM - 부모 노드

모든 노드에는 정확히 하나의 상위 노드가 있습니다. 다음 코드는 <book>의 상위 노드로 이동합니다.

예시

function myFunction(xml) {
var xmlDoc = xml.responseXML;
    var x = xmlDoc.getElementsByTagName("book")[0];
    document.getElementById("demo").innerHTML = x.parentNode.nodeName;
}

설명된 예:

  1. xmlDoc에 " books.xml " 로드
  2. 첫 번째 <book> 요소 가져오기
  3. "x"의 부모 노드의 노드 이름을 출력합니다.


빈 텍스트 노드 피하기

Firefox 및 일부 다른 브라우저는 빈 공백이나 새 줄을 텍스트 노드로 처리하지만 Internet Explorer는 처리하지 않습니다.

이것은 속성을 사용할 때 문제를 일으킵니다: firstChild, lastChild, nextSibling, previousSibling.

빈 텍스트 노드(요소 노드 사이의 공백 및 개행 문자)로 이동하는 것을 방지하기 위해 노드 유형을 확인하는 함수를 사용합니다.

function get_nextSibling(n) {
    var y = n.nextSibling;
    while (y.nodeType! = 1) {
        y = y.nextSibling;
    }
    return y;
}

위의 함수를 사용 하면 속성 노드 .nextSibling 대신 get_nextSibling( node )을 사용할 수 있습니다.

코드 설명:

요소 노드는 유형 1입니다. 형제 노드가 요소 노드가 아닌 경우 요소 노드를 찾을 때까지 다음 노드로 이동합니다. 이렇게 하면 Internet Explorer와 Firefox 모두에서 결과가 동일합니다.


첫 번째 자식 요소 가져오기

다음 코드는 첫 번째 <book>의 첫 번째 요소 노드를 표시합니다.

예시

<!DOCTYPE html>
<html>
<body>

<p id="demo"></p>

<script>
var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
        myFunction(this);
    }
};
xhttp.open("GET", "books.xml", true);
xhttp.send();

function myFunction(xml) {
    var xmlDoc = xml.responseXML;
    var x = get_firstChild(xmlDoc.getElementsByTagName("book")[0]);
    document.getElementById("demo").innerHTML = x.nodeName;
}

//check if the first node is an element node
function get_firstChild(n) {
    var y = n.firstChild;
    while (y.nodeType != 1) {
        y = y.nextSibling;
    }
    return y;
}
</script>

</body>
</html>

산출:

title

설명된 예:

  1. xmlDoc에 " books.xml " 로드
  2. 첫 번째 <book> 요소 노드에서 get_firstChild 함수를 사용하여 요소 노드인 첫 번째 자식 노드를 가져옵니다.
  3. 요소 노드인 첫 번째 자식 노드의 노드 이름 출력

더 많은 예


이 예제에서는 lastChild() 메서드와 사용자 지정 함수를 사용하여 노드의 마지막 자식 노드를 가져옵니다.


이 예제는 nextSibling() 메서드와 사용자 정의 함수를 사용하여 노드의 다음 형제 노드를 가져옵니다.


이 예제에서는 previousSibling() 메서드와 사용자 지정 함수를 사용하여 노드의 이전 형제 노드를 가져옵니다.