You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
- Größer/kleiner als oder gleich: <code>a >= b</code>, <code>a <= b</code>.
7
7
- Gleich: `a == b` (beachte bitte das doppelte Gleichheitszeichen `=`. Ein einfaches Gleichheitszeiten `a = b` würde eine Zuweisung bedeuten).
8
8
- Ungleich. In der Mathematik lautet die Notation <code>≠</code>, aber in JavaScript wird es als eine Zuweisung mit einem Ausrufezeichen davor geschrieben: <code>a != b</code>.
9
9
10
10
## Das Ergebnis ist Boolean
11
11
12
12
Wie alle anderen Operatoren liefert ein Vergleich einen Wert. In diesem Fall ist der Wert ein boolscher Wert.
13
13
14
-
-`true`(engl. "wahr") -- bedeutet "ja", "richtig" oder "die Wahrheit".
15
-
-`false`(engl. "unwahr") -- bedeutet "nein", "falsch" oder "nicht die Wahrheit".
14
+
-`true` -- bedeutet "ja", "richtig" oder "die Wahrheit".
15
+
-`false` -- bedeutet "nein", "falsch" oder "nicht die Wahrheit".
16
16
17
17
Zum Beispiel:
18
18
@@ -26,14 +26,14 @@ Ein Vergleichsergebnis kann einer Variablen zugewiesen werden, genau wie jeder a
26
26
27
27
```js run
28
28
let result =5>4; // das Ergebnis des Vergleichs zuweisen
29
-
alert( result ); // true (wahr)
29
+
alert( result ); // true
30
30
```
31
31
32
32
## String Vergleiche
33
33
34
-
Um zu sehen, ob ein String (Zeichenfolge) größer als ein anderer ist, verwendet JavaScript die so genannte "Wörterbuch-" oder "lexikografische" Reihenfolge.
34
+
Um zu sehen, ob ein String größer als ein anderer ist, verwendet JavaScript die so genannte "Wörterbuch-" oder "lexikografische" Reihenfolge.
35
35
36
-
Mit anderen Worten, die Strings werden Buchstabe für Buchstabe verglichen.
36
+
Mit anderen Worten, Strings werden Buchstabe für Buchstabe verglichen.
37
37
38
38
Zum Beispiel:
39
39
@@ -46,7 +46,7 @@ alert( 'Bee' > 'Be' ); // true
46
46
Der Algorithmus zum Vergleichen zweier Strings ist einfach:
47
47
48
48
1. Vergleiche das erste Zeichen der beiden Strings.
49
-
2. Wenn das erste Zeichen aus dem ersten String größer (oder kleiner) als das des anderen String ist, dann ist der erste String größer (oder kleiner) als der zweite. Das war's.
49
+
2. Wenn das erste Zeichen aus dem ersten String größer (oder kleiner) als das des anderen Strings ist, dann ist der erste String größer (oder kleiner) als der zweite. Das war's.
50
50
3. Andernfalls, wenn die ersten Zeichen beider Strings gleich sind, vergleiche die zweiten Zeichen auf die gleiche Weise.
51
51
4. Wiederhole dies bis zum Ende einer der beiden Strings.
52
52
5. Wenn beide Strings mit der gleichen Länge enden, dann sind sie gleich. Andernfalls ist der längere String größer.
@@ -63,15 +63,15 @@ Der oben angegebene Vergleichsalgorithmus entspricht in etwa dem, der in Wörter
63
63
Zum Beispiel, Groß/Kleinschreibung ist wichtig. Ein Großbuchstabe `"A"` ist nicht gleich dem Kleinbuchstaben `"a"`. Welcher ist größer? Der Kleinbuchstabe `"a"`. Und warum? Weil das Kleinbuchstabenzeichen einen größeren Index in der internen Codierungstabelle hat, die JavaScript verwendet (Unicode). Wir werden im Kapitel <info:string> auf die spezifischen Details und die Konsequenzen dieser Tatsache zurückkommen.
64
64
```
65
65
66
-
## Vergleiche von verschiedenen Datentypen
66
+
## Vergleich von verschiedenen Typen
67
67
68
-
Beim Vergleich von Werten verschiedener Datentypen wandelt JavaScript die Werte in `number` (Zahlen) um.
68
+
Beim Vergleichen von Werten verschiedener Typen konvertiert JavaScript die Werte in Zahlen.
69
69
70
70
Zum Beispiel:
71
71
72
72
```js run
73
-
alert( '2'>1 ); // true, der String '2' wird zu number 2
74
-
alert( '01'==1 ); // true, der String '01' wird zu number 1
73
+
alert( '2'>1 ); // true, String '2' wird zur Zahl 2
74
+
alert( '01'==1 ); // true, String '01' wird zur Zahl 1
75
75
```
76
76
77
77
Bei boolschen Werten wird `true` zu `1` und `false` zu `0`.
@@ -101,7 +101,7 @@ alert( Boolean(b) ); // true
101
101
alert(a == b); // true!
102
102
```
103
103
104
-
Aus der Sicht von JavaScript ist dieses Ergebnis ganz normal. Eine Gleichheitsprüfung konvertiert Werte mit Hilfe der numerischen Datentypumwandlung (daher wird `"0"` zu `0`), während die explizite Umwandlung in `Boolean` andere Regeln verwendet.
104
+
Aus Sicht von JavaScript ist dieses Ergebnis ganz normal. Eine Gleichheitsprüfung konvertiert Werte unter Verwendung der numerischen Konvertierung (daher wird `"0"` zu `0`), während die explizite Konvertierung in `Boolean` einen anderen Regelsatz verwendet.
105
105
````
106
106
107
107
## Strikte Gleichheit
@@ -118,13 +118,13 @@ Dasselbe geschieht mit einem leeren String:
118
118
alert( ''==false ); // true
119
119
```
120
120
121
-
Dies geschieht, weil Operanden unterschiedlichen Typs mit dem Gleichheitsoperator `==` in `number` umgewandelt werden. Ein leerer String wird, genau wie bei `false`, zu einer numerischen Null.
121
+
Dies geschieht, weil Operanden unterschiedlichen Typs mit dem Gleichheitsoperator `==` in Zahlen umgewandelt werden. Ein leerer String wird, genau wie bei `false`, zu einer Null.
122
122
123
123
Was ist zu tun, wenn wir `0` von `false` unterscheiden wollen?
124
124
125
-
**Der strikte Gleichheitsoperator `===`überprüft auf Gleichheit ohne Datentypumwandlung.**
125
+
**Ein strikter Gleichheitsoperator `===`prüft auf Gleichheit ohne Datentypumwandlung.**
126
126
127
-
Mit anderen Worten, wenn `a` und `b`von unterschiedlichem Datentyp sind, dann gibt `a === b` sofort `false` zurück, ohne einen Versuch, sie zu konvertieren.
127
+
Mit anderen Worten, wenn `a` und `b`unterschiedliche Typen sind, gibt `a === b` sofort `false` zurück, ohne sie zu konvertieren.
128
128
129
129
Versuchen wir es:
130
130
@@ -138,7 +138,7 @@ Der Operator für strikte Gleichheit ist etwas länger zu schreiben, macht aber
138
138
139
139
## Vergleiche mit null und undefined
140
140
141
-
Es gibt ein nicht-intuitives Verhalten, wenn `null` oder `undefined` mit anderen Werten verglichen wird.
141
+
Es gibt ein nichtintuitives Verhalten, wenn `null` oder `undefined` mit anderen Werten verglichen wird.
142
142
143
143
Für die strikte Gleichheitsprüfung `===`
144
144
: sind diese Werte unterschiedlich, weil jeder von ihnen ein verschiedener Datentyp ist.
@@ -147,15 +147,15 @@ Für die strikte Gleichheitsprüfung `===`
147
147
alert( null === undefined ); // false
148
148
```
149
149
150
-
Für die nicht-strikte Gleichheitsprüfung`==`
150
+
Für die nichtstrikte Kontrolle`==`
151
151
: gibt es eine besondere Regel. Diese beiden sind ein "süßes Pärchen": sie sind gleich (im Sinne von `==`), aber nicht irgendeinem anderen Wert.
152
152
153
153
```js run
154
154
alert( null == undefined ); // true
155
155
```
156
156
157
157
Für mathematische und andere Vergleiche `< > <= >=`
158
-
: werden `null/undefined`umgewandelt in number (Zahlen): `null` wird zu `0`, während `undefined` zu `NaN` wird.
158
+
: `null/undefined`werden in Zahlen umgewandelt: `null` wird zu `0`, während `undefined` zu `NaN` wird.
159
159
160
160
Jetzt wollen wir sehen, was bei der Anwendung dieser Regeln passiert. Und, was noch wichtiger ist, wie man damit nicht in eine Falle tappt.
Mathematisch gesehen ist das seltsam. Das letzte Ergebnis besagt, dass "`null` größer oder gleich `0` ist", so dass es in einem der obigen Vergleiche `true` sein muss, aber beide sind `false`.
173
173
174
-
Der Grund ist, dass die Gleichheitsprüfung `==` und vergleichende Operatoren `> < >= <=` verschieden funktionieren. Vergleichende Operatoren wandeln `null` in eine `number` um, behandeln es als `0`. Deshalb ist (3) `null >= 0``true` und (1) `null > 0``false`.
174
+
Der Grund ist, dass die Gleichheitsprüfung `==` und vergleichende Operatoren `> < >= <=` verschieden funktionieren. Vergleichende Operatoren wandeln `null` in eine Zahl um, behandeln es als `0`. Deshalb ist (3) `null >= 0``true` und (1) `null > 0``false`.
175
175
176
176
Auf der anderen Seite ist die Gleichheitsprüfung `==` für `undefined` und `null` so definiert, dass sie ohne Umwandlung einander gleich sind, aber nichts anderem. Deshalb ist (2) `null == 0``false`.
177
177
@@ -202,8 +202,8 @@ Verwende keine Vergleiche `>= > < <=` mit einer Variablen, die `null/undefined`
202
202
203
203
## Zusammenfassung
204
204
205
-
-Vergleichende Operatoren geben einen boolschen Wert zurück.
206
-
- Strings (Zeichenfolgen) werden Buchstabe für Buchstabe in der "Wörterbuch"-Reihenfolge verglichen.
207
-
- Wenn Werte unterschiedlichen Typs verglichen werden, werden sie in Zahlen (`number`) umgewandelt (außer bei der strikten Gleichheitsprüfung).
205
+
-Vergleichsoperatoren geben einen boolschen Wert zurück.
206
+
- Strings werden Buchstabe für Buchstabe in der "Wörterbuch"-Reihenfolge verglichen.
207
+
- Wenn Werte verschiedener Typen verglichen werden, werden sie in Zahlen umgewandelt (unter Ausschluss einer strikten Gleichheitsprüfung).
208
208
- Die Werte `null` und `undefined` sind gleich `==`, aber ansonsten ist nichts gleich den zwei Werten.
209
209
- Sei vorsichtig, wenn du Vergleiche wie `>` oder `<` mit Variablen verwendest, die gelegentlich `null/undefined` sein können. Es ist eine gute Idee, `null/undefined` separat zu prüfen.
0 commit comments