JS 요소 선택자 알아보기 본문
반응형
요소선택
자바 스크립트에서 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
NodeList(3)
▶ 0 : li
▶ 1 : li
▶ 2 : li
length : 3
반응형
'MarkUp' 카테고리의 다른 글
CSS 기본과 사용법을 알아보자! (5) | 2022.08.12 |
---|---|
비트맵과 벡터의 차이는 무엇일까? (13) | 2022.08.09 |
웹 표준, 웹 호환성, 웹 접근성을 알아보자! (10) | 2022.08.08 |
JS 전역변수와 지역변수 (13) | 2022.07.28 |
JS 데이터 타입 이해하기 (12) | 2022.07.25 |
Comments