본문 바로가기

JS 요소 선택자 알아보기 본문

MarkUp

JS 요소 선택자 알아보기

개발자로 거듭나기 2022. 8. 5. 14:45
반응형

요소선택

자바 스크립트에서 html요소를 선택해서 제어할 수 있는데, 이러한 선택자들을 요소선택자라고 한다. 선택할 요소로는 태그, 클래스, 아이디 등을 선택할 수 있습니다. 이러한 선택자 API들을 이용해 DOM에서 Element 노드를 선택자를 통해 빠르고 쉽게 가져올 수 있는 메서드를 제공합니다.


▶ 요소를 직접 선택하는 메서드

메서드 설명
getElementById() document.getElementById('content')일 경우, HTML 요소 중 id 속성이 'content'인 요소를 선택합니다.
getElementsByClassName() document.getElementByClassName('menu')일 경우 HTML 요소 중 class명이 'menu'인 요소들을 선택합니다.
getElementsByTagName() document.getElementByTagName('ul')일 경우 HTML 요소 중 태그명이 'ul'인 요소들을 선택합니다.
getElementByName() document.getElementByName('txt')일 경우 HTML 요소 중 name명이 'txt'인 요소들을 선택합니다.
querySelector() 요소의 선택 방법이 css 선택 방법과 같습니다. 선택된 요소중 첫 번째 요소만 선택 합니다.
document.querySelector('.lnb');
document.querySelector(div);
document.querySelector('#gnb li');
querySelectorAll() querySelector()는 선택된 요소 중 첫 번째 요소만 선택하는 반면 querySelectorAll()는 모든 요소를 선택합니다.

반응형

요소 선택자 사용 방법

<!DOCTYPE html>
<html lang="ko">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>요소를 직접 선택하는 메서드</title>
    <script>
        window.onload(() => {
            let list1 = document.querySelector('#box1 > ul > li'); // id가 box1 인 자식의 ul 자식의 li태그 선택
            let list2 = document.querySelectorAll('#box2 > ul > li'); // id가 box2 인 자식의 ul 자식의 모든 li태그 선택
            
            console.log(list1); // <li>내용1</li>
            console.log(list2); // NodeList(3) [0 : li, 1: li, 2 : li]

            // list1.style.background = '#ff6600'; // 요소 선택자들을 이용해 css도 적용 가능
            // list2[0].style.background = '#ccc';
            // list2.item(1).style.background = '#ddd';
        });
    </script>
</head>
<body>
    <div id="box1">
        <ul>
            <li>내용 1</li>
            <li>내용 2</li>
            <li>내용 3</li>
        </ul>
    </div>
    <div id="box2">
        <ul>
            <li>내용 4</li>
            <li>내용 5</li>
            <li>내용 6</li>
        </ul>
    </div>    
</body>
</html>
결과 확인하기
<li>내용 1</li>
NodeList(3)
▶ 0 : li
▶ 1 : li
▶ 2 : li
length : 3
반응형
Comments