Notice
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- event
- 애니메이션
- ios
- video
- 모듈
- This
- Flex
- 문자열
- 스크롤
- 클로저
- dom
- scroll
- 고차함수
- animation
- 배열
- json
- 이벤트 루프
- IntersectionObserver
- 비동기
- Push
- ES6
- array
- 이벤트
- ajax
- object
- Promise
- slice
- async
- 이벤트 위임
- input
Archives
- Today
- Total
FEDev Story
DOM 탐색 본문
DOM 탐색 방법
라이브 콜렉션에서의 반복은 느리며 상당히 비싼 자원을 소비한다.
따라서 콜렉션이 라이브일 필요가 없을 때는 콜렉션을
ES6에서 이는
- ID로 요소 검색 (document.getElementById)
- 태그 이름으로 검색 (document.getElementByTagName)
- CSS 선택자로 요소 검색 (document.querySelector)
<article id="bar">
<h2>Lorem ipsum</h2>
</article>
<script>
var article = document.querySelector( "#bar" ),
heading = article.querySelector( "h2" );
</script>
선택자는 하나 이상의 타입(태그) 선택자와 클래스 선택자, ID 선택자, 속성 선택자 또는 의사 클래스 선택자로 매우 다양한 조합이 가능하기 때문에
자바스크립트에서 HTML 요소를 바인딩하는 것은 쉽지 않다.
따라서 data-*
속성 선택자를 사용할 것을 추천한다.
<article data-bind="bar">
<h2 data-bind="heading">Lorem ipsum</h2>
</article>
<script>
var article = document.querySelector( "[data-bind=\"bar\"]" ),
heading = article.querySelector( "[data-bind=\"heading\"]" );
</script>
이 방법은 HTML 구조에서 자유로우며 CSS 클래스 독립적이기 때문에 안전하게 CSS를 리팩토링할 수 있다. 또한 문서마다 고유한 값을 가지는 ID에 한정되지도 않는다.
querySelector
가 DOM에서 선택자와 일치하는 첫번째 요소를 가져오는 반면, querySelectAll
는 모든 요소를 검색한다.
<ul data-bind="bar">
<li data-bind="item">Lorem ipsum</li>
<li data-bind="item">Lorem ipsum</li>
<li data-bind="item">Lorem ipsum</li>
</ul>
<script>
var ul = document.querySelector( "[data-bind=\"bar\"]" ),
lis = ul.querySelectorAll( "[data-bind=\"item\"]" );
console.log( lis.length );
</script>
검색된 요소는 NodeList로 표시되며 배열은 아니다. DOM이 리플로될 때마다 업데이트되는 라이브 콜렉션이다.라이브 콜렉션에서의 반복은 느리며 상당히 비싼 자원을 소비한다.
따라서 콜렉션이 라이브일 필요가 없을 때는 콜렉션을
[].slice.call(nodelist)
과 같은 배열로 변환한다.ES6에서 이는
[...nodeList]
spread 연산자를 사용해 수행할 수 있다.
var ul = document.querySelector( "[data-bind=\"bar\"]" ),
lis = ul.querySelectorAll( "[data-bind=\"item\"]" );
console.log( [].slice.call( lis ) ); // into array ES5 way
console.log( [ ...lis ] ); // into array ES6 way
발견된 요소가 지정된 선택자와 일치하는지의 여부도 테스트할 수 있다.
console.log(el.matches(".foo > .bar"));
console.log(input.matches(":checked"));
Comments