for...in, instruction
Mise à jour : novembre 2007
Exécute une ou plusieurs instructions pour chaque propriété d'un objet ou chaque élément d'un tableau ou d'une collection.
for ( [var] variable in {object | array | collection})
statement
Arguments
variable
Obligatoire. Variable pouvant représenter n'importe quel nom de propriété de object, n'importe quel index de array ou n'importe quel élément de collection.object
Objet JScript sur lequel vous souhaitez effectuer une itération.array
Tableau sur lequel vous souhaitez effectuer une itération. Cela peut être un objet JScript Array ou un tableau .NET Framework.collection
Collection sur laquelle vous souhaitez effectuer une itération. Cela peut être toute classe qui implémente les interfaces IEnumerable ou IEnumerator à partir du .NET Framework.statement
Facultatif. Instructions à exécuter pour chaque propriété de object ou chaque élément de array ou de collection. Il peut s'agir d'une instruction composée.
Notes
Avant chaque itération d'une boucle, le nom de propriété suivant de object, l'index suivant de array ou l'élément suivant de collection est assigné à l'argument variable. Vous pouvez utiliser variable dans n'importe laquelle des instructions incluses dans la boucle pour référencer la propriété de object ou l'élément de array.
Lors d'une itération sur un objet, il n'existe aucun moyen de déterminer ou de contrôler l'ordre dans lequel les noms de membres de l'objet sont assignés à l'argument variable. L'instruction for...in ne permet pas d'effectuer une boucle sur les membres d'objets non-JScript, tels que les objets .NET Framework.
L'itération s'effectue sur les tableaux dans l'ordre des éléments, du plus petit index au plus grand. Comme les objets JScript Array peuvent être creux, l'instruction for...in accède uniquement aux éléments définis du tableau. Les objets JScript Array peuvent également disposer de propriétés expando, auquel cas des index de tableau sont assignés à l'argument variable en tant que noms de propriétés. Si le tableau est un tableau .NET Framework multidimensionnel, seule la première dimension est énumérée.
Pour une itération sur une collection, les éléments sont assignés à variable dans l'ordre où ils apparaissent dans la collection.
Exemple 1
L'exemple ci-dessous illustre l'utilisation de l'instruction for…in avec un objet utilisé comme tableau associatif.
function ForInDemo1() {
var ret = "";
// Initialize the object with properties and values.
var obj : Object = {"a" : "Athens" ,
"b" : "Belgrade",
"c" : "Cairo"};
// Iterate over the properties.
for (var key in obj)
// Loop and assign 'a', 'b', and 'c' to key.
ret += key + ":\t" + obj[key] + "\n";
return(ret);
} // ForInDemo1
Cette fonction retourne la chaîne qui contient :
a: Athens
b: Belgrade
c: Cairo
Exemple 2
Cet exemple illustre l'utilisation de l'instruction for…in avec un objet JScript Array qui possède des propriétés expando.
function ForInDemo2() {
var ret = "";
// Initialize the array.
var arr : Array = new Array("zero","one","two");
// Add a few expando properties to the array.
arr["orange"] = "fruit";
arr["carrot"] = "vegetable";
// Iterate over the properties and elements.
for (var key in arr)
// Loop and assign 0, 1, 2, 'orange', and 'carrot' to key.
ret += key + ":\t" + arr[key] + "\n";
return(ret);
} // ForInDemo2
Cette fonction retourne la chaîne qui contient :
0: zero
1: one
2: two
orange: fruit
carrot: vegetable
Exemple 3
L'exemple ci-dessous illustre l'utilisation de l'instruction for…in avec une collection. Dans cet exemple, la méthode GetEnumerator de l'objet System.String fournit une collection des caractères dans la chaîne.
function ForInDemo3() {
var ret = "";
// Initialize collection.
var str : System.String = "Test.";
var chars : System.CharEnumerator = str.GetEnumerator();
// Iterate over the collection elements.
var i : int = 0;
for (var elem in chars) {
// Loop and assign 'T', 'e', 's', 't', and '.' to elem.
ret += i + ":\t" + elem + "\n";
i++;
}
return(ret);
} // ForInDemo3
Cette fonction retourne la chaîne qui contient :
0: T
1: e
2: s
3: t
4: .
Configuration requise
Remarque : |
---|
Pour effectuer des boucles sur des collections, Version .NET est requis. |