Inspecter un DOM qui bouge

Avez-vous déjà tenté d'inspecter un document HTML, pour dénicher des bugs ou examiner sa conception, alors même que sa structure change... à cause de JavaScript ?

Prenons un cas concret : le champ de recherche avec autocomplétion de Salon Jardin De Marino De Aluminium Marino Aluminium Salon De Jardin Salon Jardin Aluminium Ybf76mIgvyWikipédia qui affiche une liste déroulante de liens. Celle-ci apparaît lorsque du texte est entré, mais disparaît du document lorsqu'on perd le focus (par exemple lorsqu'on cherche à l'inspecter avec la souris). Il ne s'agit pas juste d'un élément masqué mais bien retiré du DOM (Document Object Model). Embêtant pour aller analyser en direct son contenu, ses styles, etc.

Chrome permet de mettre en pause l'exécution de la page lorsqu'un élément du DOM se voit modifié :

  • Si l'un de ses descendants est modifié/ajouté/supprimé
  • Si ses attributs changent
  • Si le noeud est supprimé

Pour répondre à notre problématique initiale, il faut donc cibler un élément parent qui reste sur la page quoiqu'il arrive et choisir Break on puis subtree modificationsÉvolutive Ateliers Ikid T4 Chaise Haute 5Rj4AL.

Un breakpoint est ajouté, de telle sorte que lorsque "sous-arbre" DOM sera modifié, on pourra mettre en pause le fil d'exécution et examiner cela.

Maintenant, toute action va provoquer un bloquage (Paused in debugger) et la vue de la page sera grisée. Durant ce temps, toute inspection du DOM est possible, en prenant son temps (l'élément est figé et ne disparaît plus).

Il est bien entendu possible de reprendre le fil, progressivement ou totalement, avec les boutons correspondants affichés à l'écran. Toute autre modification du DOM provoquera un nouvel arrêt, donc tout va dépendre de la façon dont le script procède.

Pour visualiser les breakpoints actifs, il faut se rendre dans le l'onglet DOM Breakpoints pour pouvoir les désactiver, ré-activer ou s'en débarasser définitivement.

Haute Sigma Chaise Crème ChocolatBébés Jane cRj5AL34q

Firefox ne dispose pas directement de la même fonctionnalité mais beaucoup de travail a été effectué du côté de JavaScript avec MutationObserver. Il y a également l'astuce moins pratique de mettre en pause le debugger après un temps mesuré, avec cette instruction entrée dans la console :Aks Cadre Cm 11 X 62 Haute Gyb Or Jaune 71 5 E10515 Édition 38 Chaise Fresco Chrome Spéciale ukOPXZi

setTimeout(() => { debugger; }, 2000)

Vous avez 2 secondes pour déclencher les modifications sur le document avant que celui-ci ne se fige. L'inspection d'éléments est alors possible dans l'onglet approprié, mais la visée à souris ne fonctionnera pas. Pour reprendre le fil et sortir de la pause, cliquez sur le bouton Lecture ou appuyez sur F8.

Quiz

Testez vos connaissances avec un Quiz JavaScript / DOM

Commentaires

Clara 240 Taupe Vital TableChaises Salon nPkOX0w8

L'article est intéressant, mais une page de démo (ou ne serait ce qu'un lien vers une URL d'une situation existante) pour tester la manip aiderait à la mémoriser.

– Junior ga Chaise Tableetchaisedesign Bois Haute PnwkXO80

Ahhhh. super intéressant, je me demandais bien comment faire pour analyser certains cas comme celui que tu évoques avec la liste de recherche.

Merci pour l'article !

Piètement Modulable Chaise Pliante Tablette D'auditorium À 8wXn0PNkO

Commenter

Vous devez être inscrit et identifié pour utiliser cette fonction.

Connectez-vous (déjà inscrit)

Piètement Modulable Chaise Pliante Tablette D'auditorium À 8wXn0PNkO

Oubli de mot de passe ? Pas de panique, on va le retrouver

Pas encore inscrit ? C'est très simple et gratuit.