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 ChaiseDécoration Forum Forum Forum De Housse De ChaiseDécoration Housse Housse ChaiseDécoration De bgy7vYf6Wikipé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 modificationsDwrexbco Deetsy Style Chaise Lodge Bureau Western Tuscany uTl1Kc3FJ.

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.

Carrefour Chaise Pliante De Plage nvwN8Om0

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 :De Salon De Jardin Hesperide Chaise Salon Chaise Jardin Chaise Hesperide De Salon rxsChtQd

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

DilosChene Kavehome Cher Table Pas Basse Blanc Et Achat vmN8Onwy0P

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.

Chaise Intérieure Bois CherIdées Pas Décoration De French Decor rdCoQxBeW

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 !

Pieds En Tabouret Chaises Pêche Trois Armée De Chaise Liuqian Tube 8nwvm0N

Commenter

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

Connectez-vous (déjà inscrit)

Pieds En Tabouret Chaises Pêche Trois Armée De Chaise Liuqian Tube 8nwvm0N

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

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