Maison interface Web js tutoriel Explication détaillée des opérations DOM en JavaScript

Explication détaillée des opérations DOM en JavaScript

Aug 13, 2017 am 10:33 AM
javascript js 详解

1. Qu'est-ce que DOM

JavaScript se compose de trois parties : ECMAScript, DOM et DOM représentent la méthode et l'interface pour décrire le contenu Web, c'est-à-dire. c'est-à-dire le modèle objet de document (Document Object Model). Sur une page Web, les objets qui organisent la page (ou le document) sont organisés dans une structure arborescente. Le modèle standard utilisé pour représenter les objets dans le document est appelé DOM, et la structure arborescente est ce que nous appelons souvent l'arborescence DOM.

L'introduction du DOM dans Wikipédia est plus précise : DOM est une interface de programmation d'applications multiplateforme et indépendante du langage qui traite les documents HTML, XHTML ou XML actuels sous la forme d'une arborescence, dans laquelle chaque nœud est un objet. , chaque nœud représente une partie du document.

2. Nœuds DOM

1. Types de nœuds

L'arborescence DOM est composée de nombreux types de nœuds différents, et ces types de nœuds ont une valeur nodeType Nous pouvons utiliser la valeur nodeType pour déterminer si ce que nous obtenons ou voulons est un nœud du type correspondant.

节点类型 元素节点(标签节点) 属性节点 文本节点(空格、换行、文字) 注释节点 document节点
nodeType值 1 2 3 8 9

En plus de juger le type via la valeur nodeType, nous pouvons également afficher les noms de nœuds d'éléments et d'attributs via nodeName, et utiliser nadeValue pour afficher les valeurs d'attribut des nœuds d'attribut.

2. Obtenez le nœud d'élément


document.getElementById(id);
document.getElementByTagName(tagname);
document.getElementByClassName(classname);
Copier après la connexion

Habituellement, vous voulez Lors de la modification de ou de l'utilisation de nœuds d'élément dans HML en JavaScript, ils doivent être obtenus avant d'appeler. Ensuite, nous l'obtenons en définissant l'attribut Id ou l'attribut Class de l'élément, ou en utilisant le nom de la balise pour l'obtenir. . Mais sachez que la méthode getElementById() ne fonctionne pas en XML. Dans les documents XML, les recherches doivent être effectuées en ayant l'attribut id, et ce type doit être déclaré dans la DTD XML.

Après avoir obtenu le nœud que nous voulons, nous pouvons également faire fonctionner d'autres nœuds grâce à la relation des nœuds. Ici, nous prenons l'élément p comme nœud d'élément initial comme exemple.

 2.1 Nœuds enfants


p.children();
p.childNodes();
Copier après la connexion

Obtenez les nœuds enfants sous p, tandis que p.children() ne peut obtenir que les nœuds enfants des nœuds d'élément, tandis que p.childNodes() obtiendra tous les types de nœuds enfants, ce qui signifie qu'il analysera les nœuds de texte vides.

 2.2 Nœud parent


p.parentNode();
p.offsetParent();
Copier après la connexion

Récupère le nœud parent de p. p.offsetParent() obtient le nœud ancêtre avec l'attribut de positionnement, c'est-à-dire à partir du nœud parent, si le nœud parent If il n'y a pas d'attribut de positionnement, puis recherchez le nœud parent du nœud parent jusqu'à ce qu'un nœud avec un attribut de positionnement soit trouvé.

 2.3 Nœuds frères


//下一个兄弟节点 p.nextElementSibling();
p.nextSibling();//上一个兄弟节点 p.previousElementSibling();
p.previousSibling();
Copier après la connexion

Qu'il y ait un élément ici est essentiel, tout comme pour obtenir des nœuds enfants, p.nextSibling() et p.previousSibling() analyseront les nœuds vides et. get Entrez l'espace ci-dessous p ou appuyez sur Entrée.

 2.4 Nœuds enfants tête et queue


//获取p的第一个子节点p.firstElementChild();
p.firstChild();//获取p的最后一个子节点p.lastElementChild();
p.lastElementChild();
Copier après la connexion

La différence est la même que ci-dessus.

3. Opérations sur les nœuds

En plus d'ajouter et de supprimer des nœuds de modification en HTML, nous pouvons également opérer des nœuds en JavaScript.

 3.1 Créer un nœud


//创建节点/创建文本节点createElement();
createTextNode();
Copier après la connexion

La création de nœuds de texte est généralement utilisée pour ajouter du contenu aux nœuds d'éléments. Elle crée du texte statique et ne peut pas avoir un format HTML comme innerHTML, donc creatTextNode() est plus sûr, innerText a des problèmes de compatibilité avec le navigateur. encore.

 3.2 Ajouter un nœud

 Le nœud que nous créons ne sera pas automatiquement ajouté au HTML, nous devons faire fonctionner le nœud créé.


//向尾部添加子节点 appendChild(); 
//向目标节点之前添加insertBefore(newElement,targetElement);
Copier après la connexion

Le deuxième paramètre de insertBefore() est un paramètre facultatif. Si vous n'écrivez pas le deuxième paramètre, il sera ajouté à la queue par défaut. est équivalent à appendChild() ;

 3.3 Remplacement


//将旧节点换为新节点replaceChild(newElement,oldElement);
Copier après la connexion

p.replaceChild(newElement ,oldElement), qu'il s'agisse d'un nouveau nœud ou d'un ancien nœud, il doit s'agir d'un nœud enfant de p.

 3.4 Supprimer


removeChild();
Copier après la connexion

Notez que les nœuds enfants sont supprimés.

 3.5 Clone/Copie


//深复制或浅复制cloneNode(boolean);
Copier après la connexion

profond lorsque la valeur booléenne du paramètre est vraie La copie copiera le nœud lui-même et tous les nœuds enfants en dessous.

Lorsque la valeur booléenne du paramètre est fausse, il s'agit d'une copie superficielle, et seul le nœud lui-même sera copié.

 3.6 Déterminer s'il existe des nœuds enfants et renvoyer une valeur booléenne.

 

3.7 Propriétés
hasChildNode();
Copier après la connexion

//获取节点属性getAttribute();//设置节点属性setAttribute();//删除节点属性removeAttribute();
Copier après la connexion

  要注意的一点就是class属性不能通过setAttribute(); 设置。

三、DOM的优缺点

  DOM的优点主要表现在:易用性强,并且遍历简单,支持XPath,增强了易用性。

  DOM的缺点主要表现在:效率低,解析速度慢,内存占用量过高。

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

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Explication détaillée de l'obtention des droits d'administrateur dans Win11 Explication détaillée de l'obtention des droits d'administrateur dans Win11 Mar 08, 2024 pm 03:06 PM

Le système d'exploitation Windows est l'un des systèmes d'exploitation les plus populaires au monde et sa nouvelle version Win11 a beaucoup attiré l'attention. Dans le système Win11, l'obtention des droits d'administrateur est une opération importante. Les droits d'administrateur permettent aux utilisateurs d'effectuer davantage d'opérations et de paramètres sur le système. Cet article présentera en détail comment obtenir les autorisations d'administrateur dans le système Win11 et comment gérer efficacement les autorisations. Dans le système Win11, les droits d'administrateur sont divisés en deux types : administrateur local et administrateur de domaine. Un administrateur local dispose de tous les droits d'administration sur l'ordinateur local

Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Apr 03, 2024 am 11:55 AM

La technologie de détection et de reconnaissance des visages est déjà une technologie relativement mature et largement utilisée. Actuellement, le langage d'application Internet le plus utilisé est JS. La mise en œuvre de la détection et de la reconnaissance faciale sur le front-end Web présente des avantages et des inconvénients par rapport à la reconnaissance faciale back-end. Les avantages incluent la réduction de l'interaction réseau et de la reconnaissance en temps réel, ce qui réduit considérablement le temps d'attente des utilisateurs et améliore l'expérience utilisateur. Les inconvénients sont les suivants : il est limité par la taille du modèle et la précision est également limitée ; Comment utiliser js pour implémenter la détection de visage sur le web ? Afin de mettre en œuvre la reconnaissance faciale sur le Web, vous devez être familier avec les langages et technologies de programmation associés, tels que JavaScript, HTML, CSS, WebRTC, etc. Dans le même temps, vous devez également maîtriser les technologies pertinentes de vision par ordinateur et d’intelligence artificielle. Il convient de noter qu'en raison de la conception du côté Web

Explication détaillée du fonctionnement de la division dans Oracle SQL Explication détaillée du fonctionnement de la division dans Oracle SQL Mar 10, 2024 am 09:51 AM

Explication détaillée de l'opération de division dans OracleSQL Dans OracleSQL, l'opération de division est une opération mathématique courante et importante, utilisée pour calculer le résultat de la division de deux nombres. La division est souvent utilisée dans les requêtes de bases de données. Comprendre le fonctionnement de la division et son utilisation dans OracleSQL est donc l'une des compétences essentielles des développeurs de bases de données. Cet article discutera en détail des connaissances pertinentes sur les opérations de division dans OracleSQL et fournira des exemples de code spécifiques pour référence aux lecteurs. 1. Opération de division dans OracleSQL

Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Explication détaillée du rôle et de l'utilisation de l'opérateur modulo PHP Mar 19, 2024 pm 04:33 PM

L'opérateur modulo (%) en PHP est utilisé pour obtenir le reste de la division de deux nombres. Dans cet article, nous discuterons en détail du rôle et de l'utilisation de l'opérateur modulo et fournirons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Le rôle de l'opérateur modulo En mathématiques, lorsqu'on divise un entier par un autre entier, on obtient un quotient et un reste. Par exemple, lorsque l’on divise 10 par 3, le quotient est 3 et le reste est 1. L'opérateur modulo est utilisé pour obtenir ce reste. 2. Utilisation de l'opérateur modulo En PHP, utilisez le symbole % pour représenter le module

Explication détaillée de la fonction d'appel système Linux system() Explication détaillée de la fonction d'appel système Linux system() Feb 22, 2024 pm 08:21 PM

Explication détaillée de la fonction d'appel système Linux system() L'appel système est une partie très importante du système d'exploitation Linux. Il fournit un moyen d'interagir avec le noyau système. Parmi elles, la fonction system() est l’une des fonctions d’appel système couramment utilisées. Cet article présentera en détail l’utilisation de la fonction system() et fournira des exemples de code correspondants. Concepts de base des appels système Les appels système sont un moyen permettant aux programmes utilisateur d'interagir avec le noyau du système d'exploitation. Les programmes utilisateur demandent au système d'exploitation en appelant des fonctions d'appel système

Explication détaillée de la commande Linux curl Explication détaillée de la commande Linux curl Feb 21, 2024 pm 10:33 PM

Explication détaillée de la commande curl de Linux Résumé : curl est un puissant outil de ligne de commande utilisé pour la communication de données avec le serveur. Cet article présentera l'utilisation de base de la commande curl et fournira des exemples de code réels pour aider les lecteurs à mieux comprendre et appliquer la commande. 1. Qu’est-ce que la boucle ? curl est un outil de ligne de commande utilisé pour envoyer et recevoir diverses requêtes réseau. Il prend en charge plusieurs protocoles, tels que HTTP, FTP, TELNET, etc., et fournit des fonctions riches, telles que le téléchargement de fichiers, le téléchargement de fichiers, la transmission de données, le proxy.

La relation entre js et vue La relation entre js et vue Mar 11, 2024 pm 05:21 PM

La relation entre js et vue : 1. JS comme pierre angulaire du développement Web ; 2. L'essor de Vue.js en tant que framework front-end ; 3. La relation complémentaire entre JS et Vue ; Vue.

En savoir plus sur Promise.resolve() En savoir plus sur Promise.resolve() Feb 18, 2024 pm 07:13 PM

Une explication détaillée de Promise.resolve() nécessite des exemples de code spécifiques. Promise est un mécanisme en JavaScript pour gérer les opérations asynchrones. Dans le développement réel, il est souvent nécessaire de traiter certaines tâches asynchrones qui doivent être exécutées dans l'ordre, et la méthode Promise.resolve() est utilisée pour renvoyer un objet Promise qui a été rempli. Promise.resolve() est une méthode statique de la classe Promise, qui accepte un

See all articles