Maison > interface Web > js tutoriel > le corps du texte

Pourquoi \'0 in [1,2]\' renvoie-t-il True en JavaScript ?

Barbara Streisand
Libérer: 2024-10-26 18:20:03
original
606 Les gens l'ont consulté

Why Does

Comprendre l'opérateur "in" en JavaScript

L'opérateur "in" en JavaScript est couramment utilisé pour vérifier si une propriété ou une clé existe dans un objet. Cependant, un comportement particulier se produit lors du test de la présence de « 0 » dans un tableau.

Problème : vrais résultats inattendus

Dans un tableau sans la valeur « 0 » ", l'expression suivante est évaluée comme vraie :

var x = [1,2];
0 in x;
Copier après la connexion

Ce résultat semble contre-intuitif puisque "0" n'est pas visiblement présent dans le tableau.

Solution : indexation, pas comparaison de valeurs

L'opérateur "in" en JavaScript ne vérifie pas l'existence d'une valeur spécifique. Au lieu de cela, il vérifie si une propriété ou une clé existe. Dans le cas des tableaux, les indices sont considérés comme des propriétés.

Par conséquent, dans l'exemple ci-dessus, "0" fait référence à l'index du tableau. Puisque les tableaux sont indexés à zéro, l'index "0" est valide et existe, d'où le vrai résultat.

Exemples intuitifs

Pour illustrer davantage ce concept :

var x = [1,2];
1 in x; // true (index 1 exists)
2 in x; // false (index 2 does not exist)
Copier après la connexion

Résumé du comportement

L'opérateur "in" en JavaScript est principalement utilisé pour vérifier l'existence de propriétés ou de clés dans des objets, y compris des tableaux. Lorsqu'il est utilisé sur des tableaux, il vérifie l'existence d'indices valides, et non les valeurs spécifiques stockées dans ces indices.

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
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
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!