blob: b8c6e7ced889bf1869a3637658eba3a0381b0f15 (
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
|
---
title: 'Warning: expression closures are deprecated'
slug: Web/JavaScript/Reference/Fehler/Deprecated_expression_closures
tags:
- JavaScript
- Warning
translation_of: Web/JavaScript/Reference/Errors/Deprecated_expression_closures
---
<div>{{jsSidebar("Errors")}}</div>
<h2 id="Fehlermeldung">Fehlermeldung</h2>
<pre class="syntaxbox">Warning: expression closures are deprecated
</pre>
<h2 id="Fehlertyp">Fehlertyp</h2>
<p>Warnung. Die Ausführung von JavaScript wird nicht angehalten.</p>
<h2 id="Was_ist_falsch_gelaufen">Was ist falsch gelaufen?</h2>
<p>Die nicht standardisierte <a href="/de/docs/Web/JavaScript/Reference/Operators/Expression_closures"> Ausdrucks Closure</a> Syntax (Kurzform der Funktionssyntax) ist veraltetet und sollte nicht mehr verwendet werden. Diese Syntax wird komplett entfernt ({{bug(1083458)}}) und Skripte die diese Benutzen erzeugen dann einen {{jsxref("SyntaxError")}}.</p>
<h2 id="Beispiele">Beispiele</h2>
<h3 id="Veraltete_Syntax">Veraltete Syntax</h3>
<p>Ausdrucks Closures vermeiden geschweifte Klammern oder return Anweisungen in Funktionsdeklarationen oder in Methodendefinitionen in Objekten.</p>
<pre class="brush: js example-bad">var x = function() 1;
var obj = {
count: function() 1
};
</pre>
<h3 id="Standardsyntax">Standardsyntax</h3>
<p>Um die nicht standardisierte Ausdrucks Closures Syntax zu Standard-ECMAScript Syntax zu konvertieren müssen geschweifte Klammern und ein return Statement hinzugefügt werden.</p>
<pre class="brush: js example-good">var x = function() { return 1; }
var obj = {
count: function() { return 1; }
};
</pre>
<h3 id="Standardsyntax_mit_Arrowfunktionen">Standardsyntax mit Arrowfunktionen</h3>
<p>Alternativ können <a href="/de/docs/Web/JavaScript/Reference/Functions/Arrow_functions">Arrow-Funktionen</a> genutzt werden:</p>
<pre class="brush: js example-good">var x = () => 1;</pre>
<h3 id="Standardsyntax_mit_Kurzformmethodensyntax">Standardsyntax mit Kurzformmethodensyntax</h3>
<p>Anweisungs Closures können auch in Gettern und Settern gefunden werden:</p>
<pre class="brush: js example-bad">var obj = {
get x() 1,
set x(v) this.v = v
};
</pre>
<p>Mit ES2015 <a href="/de/docs/Web/JavaScript/Reference/Functions/Method_definitions">Methodendefinitionen</a> können diese folgendermaßen konvertiert werden :</p>
<pre class="brush: js example-good">var obj = {
get x() { return 1 },
set x(v) { this.v = v }
};
</pre>
<h2 id="Siehe_auch">Siehe auch</h2>
<ul>
<li><a href="/de/docs/Web/JavaScript/Reference/Operators/Expression_closures">Ausdrucks Closures</a></li>
<li><a href="/de/docs/Web/JavaScript/Reference/Functions/Arrow_functions">Arrow Funktionen</a></li>
<li><a href="/de/docs/Web/JavaScript/Reference/Functions/Method_definitions">Methodendefinitionen</a></li>
</ul>
|