blob: ac1b7d53b9b62c1cba6965f2b71b294d949aebc1 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
---
title: 'Warning: expression closures are deprecated'
slug: Web/JavaScript/Reference/Erreurs/Deprecated_expression_closures
tags:
- Avertissement
- JavaScript
- Warning
translation_of: Web/JavaScript/Reference/Errors/Deprecated_expression_closures
---
<div>{{jsSidebar("Errors")}}</div>
<h2 id="Message">Message</h2>
<pre class="syntaxbox">Warning: expression closures are deprecated
</pre>
<h2 id="Type_d'erreur">Type d'erreur</h2>
<p>Un avertissement, l'exécution du code JavaScript ne sera pas interrompue.</p>
<h2 id="Quel_est_le_problème">Quel est le problème ?</h2>
<p>La syntaxe non-standard avec <a href="/fr/docs/Web/JavaScript/Reference/Opérateurs/Expression_closures">une expression de fermeture</a> est dépréciée et ne devrait plus être utilisée. Cette syntaxe sera complètement retirée avec le bug {{bug(1083458)}} et les scripts qui l'utilisent déclencheront alors une exception {{jsxref("SyntaxError")}}.</p>
<h2 id="Exemples">Exemples</h2>
<h3 id="Syntaxe_dépréciée">Syntaxe dépréciée</h3>
<p>Les expression de fermeture permettent de ne pas utiliser les accolades ou les instructions <code>return</code> au sein d'une déclaration de fonction ou pour une définition de méthode dans un objet.</p>
<pre class="brush: js example-bad">var x = function() 1;
var obj = {
count: function() 1
};
</pre>
<h3 id="Syntaxe_standard">Syntaxe standard</h3>
<p>Pour convertir cette syntaxe non-standard en une syntaxe standard, il suffit d'ajouter des accolades et l'instruction return.</p>
<pre class="brush: js example-good">var x = function() { return 1; }
var obj = {
count: function() { return 1; }
};
</pre>
<h3 id="Syntaxe_standard_avec_les_fonctions_fléchées">Syntaxe standard avec les fonctions fléchées</h3>
<p>On peut aussi utiliser <a href="/fr/docs/Web/JavaScript/Reference/Fonctions/Fonctions_fléchées">les fonctions fléchées</a> :</p>
<pre class="brush: js example-good">var x = () => 1;</pre>
<h3 id="Syntaxe_standard_avec_la_notation_raccourcie_pour_les_méthodes">Syntaxe standard avec la notation raccourcie pour les méthodes</h3>
<p>On retrouve parfois les expressions de fermeture dans les accesseurs et les mutateurs, par exemple :</p>
<pre class="brush: js example-bad">var obj = {
get x() 1,
set x(v) this.v = v
};
</pre>
<p>Grâce aux <a href="/fr/docs/Web/JavaScript/Reference/Fonctions/Définition_de_méthode">définitions de méthodes</a> ES2015, on peut convertir le fragment de code précédent en :</p>
<pre class="brush: js example-good">var obj = {
get x() { return 1 },
set x(v) { this.v = v }
};
</pre>
<h2 id="Voir_aussi">Voir aussi</h2>
<ul>
<li><a href="/fr/docs/Web/JavaScript/Reference/Opérateurs/Expression_closures">Les expressions de fermeture</a></li>
<li><a href="/fr/docs/Web/JavaScript/Reference/Fonctions/Fonctions_fléchées">Les fonctions fléchées</a></li>
<li><a href="/fr/docs/Web/JavaScript/Reference/Fonctions/Définition_de_méthode">Les définitions de méthode</a></li>
</ul>
|