Maison interface Web js tutoriel Manipulation du DOM en JavaScript

Manipulation du DOM en JavaScript

Dec 20, 2024 pm 08:12 PM

DOM Manipulation in JavaScript

Jour 7 : Manipulation du DOM en JavaScript

Date : 14 décembre 2024

Bienvenue au jour 7 de votre parcours d'apprentissage JavaScript ! Le sujet d'aujourd'hui se concentre sur la Manipulation DOM, l'un des aspects les plus passionnants de JavaScript. Avec la manipulation DOM, vous pouvez mettre à jour, ajouter ou supprimer dynamiquement des éléments d'une page Web, la rendant interactive et conviviale. À la fin de la leçon d’aujourd’hui, vous créerez également un projet simple de To-Do List pour mettre vos connaissances en pratique.


1. Qu'est-ce que le DOM ?

Le Document Object Model (DOM) est une interface de programmation pour les documents Web. Il représente la structure d'un document HTML sous la forme d'une arborescence d'objets, vous permettant d'accéder et de manipuler des éléments par programme à l'aide de JavaScript.

Voici un exemple de la façon dont le DOM représente le HTML :

<html>
  <body>
    <h1>Welcome</h1>
    <p>This is a paragraph.</p>
  </body>
</html>
Copier après la connexion
Copier après la connexion

L'arborescence DOM pour ce qui précède ressemblerait à ceci :

Document
 └── html
      └── body
           ├── h1
           └── p
Copier après la connexion
Copier après la connexion

2. Accéder aux éléments DOM

Vous pouvez accéder aux éléments du DOM en utilisant plusieurs méthodes :

Utilisation de getElementById

let title = document.getElementById("title");
console.log(title); // Logs the element with ID "title"
Copier après la connexion

Utilisation de getElementsByClassName

let items = document.getElementsByClassName("item");
console.log(items); // Logs all elements with class "item"
Copier après la connexion

Utilisation de querySelector et querySelectorAll

let firstItem = document.querySelector(".item"); // First element with class "item"
let allItems = document.querySelectorAll(".item"); // All elements with class "item"
Copier après la connexion

3. Modification des éléments DOM

Modifier le contenu

Vous pouvez mettre à jour le texte ou le HTML à l'intérieur d'un élément en utilisant :

  • innerText : Met à jour le texte visible.
  • innerHTML : Met à jour le contenu HTML.
let title = document.getElementById("title");
title.innerText = "Updated Title"; // Changes visible text
title.innerHTML = "<strong>Updated Title</strong>"; // Adds HTML formatting
Copier après la connexion

Changer de style

Vous pouvez modifier directement les styles CSS d'un élément.

let title = document.getElementById("title");
title.style.color = "blue";
title.style.fontSize = "24px";
Copier après la connexion

Ajout ou suppression de classes

let box = document.getElementById("box");
box.classList.add("highlight");  // Adds a class
box.classList.remove("highlight"); // Removes a class
Copier après la connexion

4. Gestion des événements

Les événements vous permettent de rendre vos pages Web interactives. Voici quelques types d’événements courants et comment les gérer.

Gestion des événements en ligne

Dans votre HTML :

<button onclick="alert('Button Clicked!')">Click Me</button>
Copier après la connexion

Utilisation de addEventListener

Cette approche est préférée car elle sépare JavaScript du HTML.

let button = document.getElementById("btn");
button.addEventListener("click", function () {
  alert("Button Clicked!");
});
Copier après la connexion

Événements communs

  • clic : Déclenché lorsqu'un élément est cliqué.
  • mouseover : Déclenché lorsque la souris survole un élément.
  • keyup : Déclenché lorsqu'une touche est relâchée.

Exemple :

<html>
  <body>
    <h1>Welcome</h1>
    <p>This is a paragraph.</p>
  </body>
</html>
Copier après la connexion
Copier après la connexion

5. Projet : Liste de tâches

Combinons ce que vous avez appris dans une simple application To-Do List.

Structure HTML

Document
 └── html
      └── body
           ├── h1
           └── p
Copier après la connexion
Copier après la connexion

Comment ça marche

  1. L'utilisateur saisit une tâche dans le champ de saisie.
  2. Cliquer sur "Ajouter une tâche" crée un nouveau
  3. élément avec la tâche.
  4. Chaque tâche dispose d'un bouton "Supprimer" pour la supprimer.

6. Points clés à retenir

  1. Accès DOM : utilisez des méthodes telles que getElementById et querySelector.
  2. Modification DOM : modifiez le contenu, les styles et les classes de manière dynamique.
  3. Gestion des événements : utilisez addEventListener pour rendre vos pages interactives.
  4. Projet pratique : Construisez une liste de tâches pour renforcer vos connaissances.

Tâches pratiques pour le jour 7

  1. Ajoutez une fonctionnalité « Marquer comme terminé » à votre liste de tâches.
  2. Créez une application de liste de courses où les utilisateurs peuvent saisir des articles et leurs quantités.
  3. Expérimentez avec des types d'événements comme le survol de la souris et le clavier dans un petit projet.

Prochaines étapes

Demain, le Jour 8, nous explorerons la Gestion des erreurs et débogage, en apprenant à gérer les problèmes inattendus dans votre code JavaScript. À bientôt alors !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment créer et publier mes propres bibliothèques JavaScript? Comment créer et publier mes propres bibliothèques JavaScript? Mar 18, 2025 pm 03:12 PM

L'article discute de la création, de la publication et du maintien des bibliothèques JavaScript, en se concentrant sur la planification, le développement, les tests, la documentation et les stratégies de promotion.

Comment optimiser le code JavaScript pour les performances dans le navigateur? Comment optimiser le code JavaScript pour les performances dans le navigateur? Mar 18, 2025 pm 03:14 PM

L'article traite des stratégies pour optimiser les performances JavaScript dans les navigateurs, en nous concentrant sur la réduction du temps d'exécution et la minimisation de l'impact sur la vitesse de chargement de la page.

Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Que dois-je faire si je rencontre l'impression de code brouillé pour les reçus en papier thermique frontal? Apr 04, 2025 pm 02:42 PM

Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur? Comment déboguer efficacement le code JavaScript à l'aide d'outils de développeur de navigateur? Mar 18, 2025 pm 03:16 PM

L'article traite du débogage efficace de JavaScript à l'aide d'outils de développeur de navigateur, de se concentrer sur la définition des points d'arrêt, de l'utilisation de la console et d'analyser les performances.

Qui est payé plus de python ou de javascript? Qui est payé plus de python ou de javascript? Apr 04, 2025 am 12:09 AM

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

Comment utiliser les cartes source pour déboguer le code JavaScript minifié? Comment utiliser les cartes source pour déboguer le code JavaScript minifié? Mar 18, 2025 pm 03:17 PM

L'article explique comment utiliser les cartes source pour déboguer JavaScript minifiée en le mappant au code d'origine. Il discute de l'activation des cartes source, de la définition de points d'arrêt et de l'utilisation d'outils comme Chrome Devtools et WebPack.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Comment fusionner les éléments du tableau avec le même ID dans un seul objet en utilisant JavaScript? Apr 04, 2025 pm 05:09 PM

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? La différence dans Console.Log de sortie Résultat: Pourquoi les deux appels sont-ils différents? Apr 04, 2025 pm 05:12 PM

Discussion approfondie des causes profondes de la différence de sortie Console.log. Cet article analysera les différences dans les résultats de sortie de la fonction Console.log dans un morceau de code et expliquera les raisons derrière. � ...

See all articles