Maison >interface Web >js tutoriel >Pourquoi l'utilisation d'une variable globale nommée « nom » en JavaScript provoque-t-elle un comportement inattendu ?
Le cas curieux du "nom" dans les objets JavaScript
Lorsque vous travaillez avec des objets JavaScript, vous pouvez rencontrer un comportement inattendu lors de l'utilisation d'un variable nommée "nom". Cette variable a une signification unique dans différents contextes.
Considérez l'extrait de code suivant :
var name = {}; name.FirstName = 'Tom'; alert(name.FirstName); alert(name); // Weird value
Dans Chrome, alert(name.FirstName) renvoie undefined, alors qu'il fonctionne comme prévu dans IE et Firefox. De plus, alert(name) produit une valeur étrange, soulevant des questions sur son comportement.
La cause de ce problème réside dans le rôle particulier de la propriété "name" dans la portée globale de JavaScript. La propriété window.name est destinée à être une chaîne, représentant le nom de la fenêtre ou du cadre actuel. Lors de la création d'une variable globale nommée "name", elle définit implicitement window.name sur une chaîne, écrasant essentiellement la valeur spéciale.
Par la suite, en essayant d'accéder à name.FirstName, il tente de récupérer une propriété d'un primitive (chaîne) plutôt qu'un objet, ce qui donne un résultat indéfini. Ce comportement est spécifique à Chrome, qui applique l'objectif prévu de window.name en convertissant la variable globale "name" en chaîne.
Pour éviter ce problème, évitez d'utiliser "name" comme variable globale, car cela peut conduire à des résultats inattendus. En évitant cette variable, vous pouvez garantir que votre code se comporte de manière cohérente sur différents navigateurs.
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!