Maison > interface Web > js tutoriel > Pourquoi la console JavaScript de Chrome affiche-t-elle uniquement la valeur finale d'un tableau modifié ?

Pourquoi la console JavaScript de Chrome affiche-t-elle uniquement la valeur finale d'un tableau modifié ?

Patricia Arquette
Libérer: 2024-12-22 09:48:43
original
793 Les gens l'ont consulté

Why Does Chrome's JavaScript Console Show Only the Final Value of a Modified Array?

La console JavaScript de Chrome présente une évaluation d'objet inattendue

Lors d'une comparaison entre les consoles JavaScript Firefox et Chrome, un comportement particulier est apparu. Alors que Firefox imprime avec précision la valeur initiale et les modifications ultérieures d'un tableau, Chrome affiche uniquement la valeur modifiée pour les deux instances.

Problème :

Le code suivant illustre le problème :

var s = ["hi"];
console.log(s);
s[0] = "bye";
console.log(s);
Copier après la connexion

La console de Firefox produit le résultat attendu :

["hi"]
["bye"]
Copier après la connexion

Cependant, La console de Chrome affiche :

["bye"]
["bye"]
Copier après la connexion

Réponse :

Ce comportement est dû à un bug connu et désormais corrigé dans Webkit : https://bugs.webkit.org /show_bug.cgi?id=35801. Cela implique l'évaluation paresseuse des objets par la console.

L'évaluation paresseuse signifie que la console n'évalue pas un objet tant qu'il n'est pas prêt à afficher la sortie. Cela se produit même si l'objet a été modifié avant que la console ne devienne active.

Solution :

Pour éviter ce problème, on peut convertir l'objet en une représentation sous forme de chaîne avant de se connecter. it :

var s = ["hi"];
console.log(s.toString());
s[0] = "bye";
console.log(s.toString());
Copier après la connexion

Cela force l'évaluation de l'objet immédiatement, et la console affiche :

hi
bye
Copier après la connexion

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