• 회원가입
  • 로그인
  • 구글아이디로 로그인

[DOM_Element] JS - hasChildNodes() 메서드 - 자식노드유무 체크 (= hasChildNodes메서드 = 해즈차일드노우즈 메서드 = 해즈차일드노드즈 메서드)

목차

  1. hasChildNodes() 예제 - 자식노드 유무 체크
  2. hasChildNodes() 정의
  3. hasChildNodes() 구문
  4. hasChildNodes() 예제 - 자식노드 있으면 첫 번째 자식노드 삭제

 

hasChildNodes() 예제 - 자식노드 유무 체크

 

<ul id="code">

  <li>HTML</li>

  <li>CSS</li>

</ul>


<button onclick="hz()">클릭</button>


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


<script>

function hz() {

  var list = document.getElementById("code").hasChildNodes();

  document.getElementById("demo").innerHTML = list;

}

</script>

 

결과보기 


hasChildNodes() 정의


지정 노드에 자식노드 있으면 true 반환. 그렇지 않으면 false 반환.

 


 

1.

주요 브라우저 모두 지원.

2.
DOM 버전: Core Level 1 Node Object

 


 

[주의] 아래 경우도 true (자식노드 존재 O)로 판단

 

1.

ul 요소 안에 빈 공백 있는 경우
(예)

<ul id="myList"> </ul>

 

2.

ul 요소 안에 줄바꿈이 있는 경우

(예) 

<ul id="myList">

</ul>


 

hasChildNodes() 구문

 

node.hasChildNodes()

 


[매개변수]

 

없음.

 


[반환값]

 

  • (자식노드 O  ||  공백 O  ||  줄바꿈 O) 경우, true 반환.
  • (자식노드 X  &&  공백 X  &&  줄바꿈 X) 경우, false 반환.


 

hasChildNodes() 예제 - 자식노드 있으면 첫 번째 자식노드 삭제

 

<ul id="code"><li>HTML</li><li>CSS</li></ul>


<button onclick="hz()">클릭</button>


<script>

function hz() {

  var list = document.getElementById("code");

  

  if (list.hasChildNodes()) {

    list.removeChild(list.childNodes[0]);

  }

}

</script>

 

결과보기



분류 제목
DOM_Element JS - isDefaultNamespace() 메서드 - 네임스페이스가 기본값인지 체크
DOM_Element JS - isEqualNode() 메서드 - 노드 동일여부 비교 (IE9 이상)
DOM_Element JS - isSameNode() 메서드 - 노드 동일여부 비교 (IE9 이상. cf. Firefox 지원X)
DOM_Element JS - isSupported() 메서드 - 지정기능이 지정노드에 지원되는지 확인 (※ 사용 비권장)
DOM_Element JS - lang 속성 - 요소의 lang 속성값 설정/반환
DOM_Element JS - lastChild 속성 ★ = 마지막자식노드 (= lastChild속성 = 라스트차일드 속성)
DOM_Element JS - lastElementChild 속성 - 마지막 자식요소 (IE9 이상)
DOM_Element JS - namespaceURI 속성 - 네임스페이스URI (IE9 이상)
DOM_Element JS - nextSibling 속성 - 바로다음 형제노드
DOM_Element JS - nextElementSibling 속성 - 바로다음 형제요소 (IE9 이상)
DOM_Element JS - nodeName 속성 - 노드명 (= 노드이름)
DOM_Element JS - nodeType 속성 ★ - 노드타입 반환 (읽기전용) ※ 노드유형 = 노트형식 = 노드종류
DOM_Element JS - nodeValue 속성 - 지정노드의 노드값 설정/반환 (= nodeValue속성 = 노드밸류속성)
DOM_Element JS - normalize() 메서드 - 공백제거 후, 인접텍스트노드 합치기 (Element경우)
DOM_Element JS - offsetHeight 속성 - 가시높이 (= 요소실제높이 = 요소높이 height+ + paddi…
DOM_Element JS - offsetWidth 속성 ★ = 가시너비 (= 요소실제너비 = 요소너비 width + paddin…
DOM_Element JS - offsetLeft 속성 - 가시좌측위치 (= 가시왼쪽위치) (IE8 이상)
DOM_Element JS - offsetParent 속성 - static 이외의 position 갖는 최근접조상요소 (= 가장가…
DOM_Element JS - offsetTop 속성 - 가시 상단 위치 (IE8 이상)
DOM_Element JS - ownerDocument 속성 - 노드의 소유자문서를 HTMLDocument 객체로 반환
29/67
목록
찾아주셔서 감사합니다. Since 2012