코딩 스쿨 JavaScript

언어선택 : HTMLCSSJAVAJAVASCRIPTMYSQLSQL PHP

JavaScript HTML Objects

JavaScript HTML Objects: 웹 페이지의 요소 조작

HTML Objects는 JavaScript에서 웹 페이지의 각 요소를 객체로 표현한 것입니다. JavaScript를 사용하여 이러한 객체를 조작하고, 속성을 수정하거나 메서드를 호출하여 사용자와의 상호작용을 처리할 수 있습니다. 이 가이드는 JavaScript HTML Objects의 기본 개념과 사용법을 설명합니다.


1. HTML 객체란?

HTML 객체는 웹 페이지의 요소를 나타내는 JavaScript 객체입니다. 이 객체를 통해 DOM(Document Object Model)을 조작할 수 있으며, 각 요소는 객체로 표현되어 다양한 속성과 메서드를 가지고 있습니다.

1.1. 예시 HTML 구조

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>HTML Objects Example</title>
</head>
<body>
    <h1 id="title">Hello, World!</h1>
    <p class="description">This is a simple description.</p>
    <button id="changeButton">Change Title</button>
    <script src="script.js"></script>
</body>
</html>

이 HTML 코드에서 <h1>, <p>, <button> 요소가 각각 HTML 객체로 표현됩니다.


2. JavaScript를 사용하여 HTML 객체 조작하기

JavaScript를 사용하여 HTML 객체를 조작하는 방법은 여러 가지가 있습니다.

2.1. 객체 선택

JavaScript를 사용하여 HTML 객체를 선택하려면 document 객체의 메서드를 사용합니다. 가장 일반적으로 사용되는 메서드는 다음과 같습니다.

2.1.1. getElementById()

특정 ID를 가진 요소를 선택합니다.

const titleElement = document.getElementById('title');

2.1.2. getElementsByClassName()

특정 클래스를 가진 모든 요소를 선택합니다. 이 메서드는 HTMLCollection을 반환합니다.

const descriptionElements = document.getElementsByClassName('description');

2.1.3. querySelector()

CSS 선택자와 유사한 문법을 사용하여 첫 번째 요소를 선택합니다.

const firstParagraph = document.querySelector('p');


3. HTML 객체의 속성 및 메서드

JavaScript를 사용하여 HTML 객체의 속성을 수정하거나 메서드를 호출할 수 있습니다.

3.1. 속성 수정

3.1.1. textContent

요소의 텍스트 내용을 변경할 수 있습니다.

titleElement.textContent = 'New Title!';

3.1.2. innerHTML

요소의 HTML 내용을 변경할 수 있습니다.

descriptionElements[0].innerHTML = '<strong>This is a bold description.</strong>';

3.1.3. style

CSS 스타일을 수정할 수 있습니다.

titleElement.style.color = 'blue'; // 텍스트 색상 변경
titleElement.style.fontSize = '2em'; // 폰트 크기 변경


3.2. 메서드 호출

HTML 객체에는 다양한 메서드가 있으며, 이를 통해 요소를 조작할 수 있습니다.

3.2.1. classList

클래스를 추가, 제거하거나 토글할 수 있습니다.

titleElement.classList.add('highlight'); // 클래스 추가
titleElement.classList.remove('highlight'); // 클래스 제거
titleElement.classList.toggle('highlight'); // 클래스 토글

3.2.2. setAttribute()

요소의 속성을 설정할 수 있습니다.

titleElement.setAttribute('data-custom', 'customValue'); // 사용자 정의 데이터 속성 추가


4. 이벤트 처리

JavaScript를 사용하여 HTML 객체의 이벤트를 처리할 수 있습니다. 이벤트 리스너를 추가하여 사용자의 상호작용에 반응할 수 있습니다.

4.1. 클릭 이벤트

const changeButton = document.getElementById('changeButton');
changeButton.addEventListener('click', function() {
    titleElement.textContent = 'Title Changed!';
});

4.2. 마우스 오버 이벤트

titleElement.addEventListener('mouseover', function() {
    titleElement.style.color = 'red'; // 마우스 오버 시 색상 변경
});

titleElement.addEventListener('mouseout', function() {
    titleElement.style.color = ''; // 마우스 아웃 시 색상 초기화
});


5. 전체 예제: HTML 객체 조작하기

아래는 JavaScript를 사용하여 HTML 객체를 조작하는 전체 예제입니다.

5.1. HTML 코드

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>JavaScript HTML Objects Example</title>
</head>
<body>
    <h1 id="title">Hello, World!</h1>
    <p class="description">This is a simple description.</p>
    <button id="changeButton">Change Title</button>
    <script src="script.js"></script>
</body>
</html>

5.2. JavaScript 코드 (script.js)

document.addEventListener('DOMContentLoaded', function() {
    const titleElement = document.getElementById('title');
    const changeButton = document.getElementById('changeButton');

    changeButton.addEventListener('click', function() {
        titleElement.textContent = 'Title Changed!'; // 버튼 클릭 시 제목 변경
        titleElement.style.color = 'blue'; // 제목 색상 변경
    });

    titleElement.addEventListener('mouseover', function() {
        titleElement.style.fontSize = '2em'; // 마우스 오버 시 폰트 크기 변경
    });

    titleElement.addEventListener('mouseout', function() {
        titleElement.style.fontSize = ''; // 마우스 아웃 시 폰트 크기 초기화
    });
});


6. 요약

JavaScript HTML Objects는 웹 페이지의 요소를 조작하는 강력한 도구입니다. JavaScript를 사용하여 HTML 요소를 선택하고, 속성을 수정하며, 이벤트를 처리할 수 있습니다.

  • HTML 객체 선택: getElementById(), querySelector() 등을 사용하여 요소 선택.
  • 속성 및 메서드 조작: textContent, innerHTML, style 속성을 사용하여 요소 수정.
  • 이벤트 처리: addEventListener()를 사용하여 사용자 상호작용 처리.

JavaScript를 활용하여 더욱 동적이고 상호작용이 풍부한 웹 애플리케이션을 개발할 수 있습니다.


copyright ⓒ 스타트코딩 all rights reserved.
이메일 : startcodingim@gamil.com