Maison > interface Web > js tutoriel > L'ordre de boucle « for...in » de JavaScript est-il garanti et devriez-vous vous y fier ?

L'ordre de boucle « for...in » de JavaScript est-il garanti et devriez-vous vous y fier ?

Linda Hamilton
Libérer: 2024-12-22 20:20:11
original
1025 Les gens l'ont consulté

Is JavaScript's `for...in` Loop Order Guaranteed, and Should You Rely On It?

Ordre des éléments dans une boucle "for (… in …)"

En JavaScript, les boucles "for...in" itèrent à travers les propriétés énumérables d'un objet Bien que ces propriétés soient généralement accessibles dans l'ordre dans lequel elles ont été définies, il est important de noter que ce comportement est. dépendant de l'implémentation.

Selon John Resig, l'auteur de jQuery, tous les principaux navigateurs bouclent actuellement les propriétés des objets dans l'ordre de définition, à l'exception de quelques cas dans Chrome. Cependant, la spécification ECMAScript indique explicitement que ce comportement. n'est pas défini.

En pratique, toutes les implémentations ECMAScript modernes parcourent les propriétés des objets dans l'ordre dans lequel elles sont définies. Il convient de noter que les exceptions sont Chrome et Opera, qui font cela pour chaque nom de propriété non numérique. Les deux navigateurs extraient les propriétés de manière séquentielle, menant à la première propriété non numérique (cela concerne la façon dont ils implémentent les tableaux). Object.keys suit également le même ordre.

L'exemple suivant illustre clairement ce qui se passe :

var obj = {
  "first": "first",
  "2": "2",
  "34": "34",
  "1": "1",
  "second": "second"
};
for (var i in obj) { console.log(i); };
Copier après la connexion

Séquence de sortie :

  • "1"
  • "2"
  • "34"
  • "premier"
  • "deuxième"

Il est important de noter que ce comportement peut changer à tout moment. Il n’est donc pas recommandé de se fier à la commande en cours.

Conclusion : Si l'ordre est important pour vous, utilisez un tableau.

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