diff options
Diffstat (limited to 'files/fr/archive/web/javascript/handler.enumerate/index.html')
| -rw-r--r-- | files/fr/archive/web/javascript/handler.enumerate/index.html | 121 |
1 files changed, 121 insertions, 0 deletions
diff --git a/files/fr/archive/web/javascript/handler.enumerate/index.html b/files/fr/archive/web/javascript/handler.enumerate/index.html new file mode 100644 index 0000000000..40dbd33345 --- /dev/null +++ b/files/fr/archive/web/javascript/handler.enumerate/index.html @@ -0,0 +1,121 @@ +--- +title: handler.enumerate() +slug: Archive/Web/JavaScript/handler.enumerate +tags: + - ECMAScript 2015 + - JavaScript + - Méthode + - Obsolete + - Proxy + - Reference +translation_of: Archive/Web/JavaScript/handler.enumerate +--- +<div>{{JSRef}} {{obsolete_header}}</div> + +<p>La méthode <strong><code>handler.enumerate()</code></strong> représente une trappe pour les instructions {{jsxref("Instructions/for...in", "for...in")}}. Elle a été retirée du standard ECMAScript avec la septième édition (ES2016) et est dépréciée pour les navigateurs.</p> + +<h2 id="Syntaxe">Syntaxe</h2> + +<pre class="brush: js notranslate">var p = new Proxy(cible, { + enumerate(cible) { + } +}); +</pre> + +<h3 id="Paramètres">Paramètres</h3> + +<p>Le paramètre suivant est passé à la méthode <code>enumerate</code>. <code>this</code> est lié au gestionnaire.</p> + +<dl> + <dt><code>cible</code></dt> + <dd>L'objet cible.</dd> +</dl> + +<h3 id="Valeur_de_retour">Valeur de retour</h3> + +<p>La méthode <code>enumerate</code> renvoie un objet <a href="/fr/docs/Web/JavaScript/Guide/Le_protocole_iterator">itérateur</a>.</p> + +<h2 id="Description">Description</h2> + +<p>La méthode <code><strong>handler.enumerate</strong></code> est une trappe permettant d'intercepter les instructions {{jsxref("Instructions/for...in", "for...in")}}.</p> + +<h3 id="Interceptions">Interceptions</h3> + +<p>Cette trappe peut intercepter les opérations suivantes :</p> + +<ul> + <li>L'énumération de propriétés / for...in : <code>for (var name in proxy) {...}</code></li> + <li>{{jsxref("Reflect.enumerate()")}}</li> +</ul> + +<h3 id="Invariants">Invariants</h3> + +<p>Si les invariants suivants ne sont pas respectés, le proxy renverra une exception {{jsxref("TypeError")}} :</p> + +<ul> + <li>La méthode <code>enumerate</code> doit renvoyer un objet.</li> +</ul> + +<h2 id="Exemples">Exemples</h2> + +<p>Dans l'exemple qui suit, on intercepte l'instruction {{jsxref("Instructions/for...in", "for...in")}}.</p> + +<pre class="brush: js notranslate">var p = new Proxy({}, { + enumerate(cible) { + console.log("appelé"); + return ["a", "b", "c"][Symbol.iterator](); + } +}); + +for (var x in p) { // "appelé" + console.log(x); // "a" +} // "b" + // "c" +</pre> + +<p>Dans le code suivant, on ne respecte pas l'invariant.</p> + +<pre class="brush: js notranslate">var p = new Proxy({}, { + enumerate(cible) { + return 1; + } +}); + +for (var x in p) {} // exception TypeError levée +</pre> + +<p>Note : Ces deux exemples utilisent la notation raccourcie pour <a href="/fr/docs/Web/JavaScript/Reference/Fonctions/Définition_de_méthode">les définitions de méthode</a>.</p> + +<h2 id="Spécifications">Spécifications</h2> + +<table class="standard-table"> + <thead> + <tr> + <th scope="col">Spécification</th> + <th scope="col">État</th> + <th scope="col">Commentaires</th> + </tr> + </thead> + <tbody> + <tr> + <td>{{SpecName('ES2015', '#sec-proxy-object-internal-methods-and-internal-slots-enumerate', '[[Enumerate]]')}}</td> + <td>{{Spec2('ES2015')}}</td> + <td>Définition initiale. Retirée avec ECMAScript 2016 (ES7).</td> + </tr> + </tbody> +</table> + +<h2 id="Compatibilité_des_navigateurs">Compatibilité des navigateurs</h2> + +<div class="hidden">Ce tableau de compatibilité a été généré à partir de données structurées. Si vous souhaitez contribuer à ces données, n'hésitez pas à envoyer une <em>pull request</em> sur <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a>.</div> + +<p>{{Compat("javascript.builtins.Proxy.handler.enumerate")}}</p> + +<h2 id="Voir_aussi">Voir aussi</h2> + +<ul> + <li>{{jsxref("Proxy")}}</li> + <li>{{jsxref("Proxy.handler", "handler")}}</li> + <li>L'instruction {{jsxref("Instructions/for...in", "for...in")}}</li> + <li>{{jsxref("Reflect.enumerate()")}}</li> +</ul> |
