Maison > interface Web > js tutoriel > Pourquoi « console.log » affiche-t-il des informations sur les objets obsolètes après une modification en JavaScript ?

Pourquoi « console.log » affiche-t-il des informations sur les objets obsolètes après une modification en JavaScript ?

DDD
Libérer: 2024-12-17 09:56:25
original
556 Les gens l'ont consulté

Why Does `console.log` Show Outdated Object Information After Modification in JavaScript?

Dévoilement des secrets de console.log et de la manipulation d'objets

Lorsque vous travaillez avec des tableaux et des objets en JavaScript, le comportement de console.log peut être parfois déroutant. Considérez le code suivant :

foo = [{id: 1},{id: 2},{id: 3},{id: 4}, {id: 5}, ];
console.log('foo1', foo, foo.length);
foo.splice(2, 1);
console.log('foo2', foo, foo.length);
Copier après la connexion

Dans les navigateurs comme Chrome, ce code produit le résultat déroutant suivant :

foo1 [Object, Object, Object, Object, Object]  5
foo2 [Object, Object, Object, Object]  4
Copier après la connexion

Pourquoi foo2 affiche-t-il la longueur du tableau mis à jour (4) mais affiche toujours cinq objets ?

Examen des objets dans Console.log

La raison réside dans comment console.log gère les objets. Lors de la journalisation d'un objet, la console reçoit une référence de manière synchrone. Cependant, l'affichage réel des propriétés de l'objet se produit de manière asynchrone, souvent après que l'objet a été modifié.

Par conséquent, vous pouvez voir des informations obsolètes lors du développement de l'objet enregistré dans la console. Pour éviter cette confusion, la console affiche un petit « i » dans une case indiquant que la valeur affichée a été capturée au moment de la journalisation, même si l'objet a pu changer depuis.

Stratégies de journalisation

Pour contourner ce problème, envisagez d'utiliser l'une des techniques suivantes :

  • Enregistrez les valeurs d'objet individuelles : console.log(obj.foo, obj.bar, obj.baz);
  • JSON encode l'objet sous forme de chaîne : console.log(JSON.stringify(obj));
  • Re -encoder l'objet avec JSON pour maintenir l'inspectabilité : console.log(JSON.parse(JSON.stringify(obj)));

Notez que JSON a ses limites, car il supprime les propriétés non sérialisables et échoue sur les références circulaires. Pour des scénarios plus complexes, envisagez d'utiliser des mécanismes personnalisés de copie approfondie.

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!

source:php.cn
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal