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

[DOM] JS - NodeList 속성 - 노드리스트 (= 노드목록)

목차
  1. NodeList 객체
  2. NodeList 개수
  3. (HTMLCollection / NodeList) 비교

 

NodeList 객체 

 

웹문서에서 추출한 노드 집합

 


PS. 

  • HTMLCollection 객체와 거의 유사. 즉, 배열은 아니나 배열처럼 색인번호(index) 통해서 각 노드에 접근 가능. 색인번호는 0부터 시작.
  • 일부 (구형) 브라우저는 getElementsByClassName()과 같은 메서드에 대해 HTMLCollection 대신 NodeList 객체 반환.
  • 모든 브라우저는 childNodes 속성에 대해 NodeList 객체 반환.
  • 대부분 브라우저는 querySelectorAll() 메서드에 대해 NodeList 객체 반환.

 


[예제]

 

<h2>홈짱닷컴 Homzzang.com</h2>


<p>HTML</p>

<p>CSS</p>

<p>JS</p>

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


<script>

var ps = document.querySelectorAll("p");

var text = ps[1].innerHTML; // 2번째 P요소 텍스트

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

</script>

 

결과보기 

 

NodeList 개수

 

  • length 속성 :  NodeList 안의 노드 개수
  • NodeList 안 노드에 대해 반복문 적용 시 매우 유용. (2번째 예제)

 


[예제1]

 

<h2>홈짱닷컴 Homzzang.com</h2>


<p>HTML</p>

<p>CSS</p>

<p>JS</p>

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


<script>

var ps = document.querySelectorAll("p");

var num = ps.length;

document.getElementById("demo").innerHTML = num; // 4

</script>

 

결과보기


[예제2]

 

<h2>홈짱닷컴 Homzzang.com</h2>


<p>HTML</p>

<p>CSS</p>

<p>JS</p>


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


<script>

function homzzang() {

  var ps = document.querySelectorAll("p");

  var i;

  for (i = 0; i < ps.length; i++) {

    ps[i].style.color = "red";

  }

}

</script>

 

결과보기

 

(HTMLCollection / NodeList) 비교

[유사점]


  • 배열은 아니지만, 배열처럼 색인번호 통해 각 객체 안 요소(노드)에 대해 접근 가능.
  • 색인번호는 0부터 시작. (※ 반복문 가능)
  • 배열 아니기 때문에 배열 메서드 사용 불가. (예) valueOf(), push() , pop() , join()

 



[차이점]

 

HTMLCollection 

  • 이름, ID, 색인번호로 각 요소에 접근 가능.
  • 속성노드와 텍스트노드 못 갖음.


NodeList

  • 색인 번호로만 각 노드에 접근 가능.
  • 속성노드와 텍스트노드 갖을 수 있음.

 



분류 제목
HTML_Objects JS - <table> 객체 ★ 테이블 (= 표작성 = table태그 = 테이블태그)</table>
HTML_Objects JS - <td> 객체 ★ - 테이블 데이터 셀 (= 테이블셀 = td태그 = 티디태그) (HTML5수정)<…
HTML_Objects JS - <th> 객체 ★ - 테이블셀제목 (= th태그 = 티에이치태그) + th고정 (= 테이블헤드고정,…
HTML_Objects JS - <tr> 객체 ★ - 테이블행 (= 테이블가로줄 = tr태그 = 티알태그) (HTML5수정)</tr…
HTML_Objects JS - <textarea> 객체 ★ - 여러줄 입력창 (= 텍스트입력영역 = 텍스트영역 = textarea…
HTML_Objects JS - <time> 객체 - 시간날짜정의 (= time태그 = 타임태그, IE9)
HTML_Objects JS - <title> 객체 ★ - 웹문서제목 (= title태그 = 타이틀태그)
HTML_Objects JS - <track> 객체 - 미디어트랙정보 (= track태그 = 트랙태그) (IE10)</tr>
HTML_Objects JS - <u> 객체 ★ - 밑줄태그 (= u태그 = 유태그 = 언더라인태그) (HTML5재정의)
HTML_Objects JS - <ul> 객체 ★ - 순서없는리스트 (= 순서없는목록태그 = ul태그 = 유엘태그/울태그/얼태그) …
HTML_Objects JS - <var> 객체 - 변수정의 (= 변수태그 = var태그 = 바태그)
HTML_Objects JS - <video> 객체 ★ - 영상재생 (= video태그 = 비디오태그) ※ 영상파일형식별로 브라우…
CSS_Objects JS - CSSStyleDeclaration 객체 (속성값 + 메서드) 종류
CSS_Objects JS - style.cssText 속성 - 인라인스타일선언내용 설정/반환
CSS_Objects JS - style.length 속성 - 스타일 선언 개수 반환 (= 스타일렝스 속성)
CSS_Objects JS - parentRule 속성 - CSS 선택자 및 선언내용 반환 (= 패런트룰 속성) (IE9+)
CSS_Objects JS - getPropertyPriority() 메서드 - CSS우선순위표시 (= !important) 유무…
CSS_Objects JS - getPropertyValue() 메서드 ★ - CSS 속성값 얻기. (= getPropertyVa…
CSS_Objects JS - item() 메서드 - 색인번호별 CSS속성명 반환 (= item메서드 = 아이템 메서드) IE9 …
CSS_Objects JS - removeProperty() 메서드 - 제거한 CSS속성의 속성값 반환 (= removePrope…
60/67
목록
찾아주셔서 감사합니다. Since 2012