|
1 | | -# Methods of primitives |
| 1 | +# Methoden von Primitiven |
2 | 2 |
|
3 | | -JavaScript allows us to work with primitives (strings, numbers, etc.) as if they were objects. They also provide methods to call as such. We will study those soon, but first we'll see how it works because, of course, primitives are not objects (and here we will make it even clearer). |
| 3 | +JavaScript ermöglicht es uns, mit Primitiven (Zeichenketten, Zahlen usw.) zu arbeiten, als wären sie Objekte. Sie bieten auch Methoden an, die als solche aufgerufen werden können. Wir werden diese bald behandeln, doch zunächst werden wir sehen wie es funktioniert, weil Primitive natürlich keine Objekte sind (und hier werden wir es noch deutlicher machen). |
4 | 4 |
|
5 | | -Let's look at the key distinctions between primitives and objects. |
| 5 | +Schauen wir uns die wichtigsten Unterschiede zwischen Primitiven und Objekten an. |
6 | 6 |
|
7 | | -A primitive |
| 7 | +Ein Primitiv |
8 | 8 |
|
9 | | -- Is a value of a primitive type. |
10 | | -- There are 7 primitive types: `string`, `number`, `bigint`, `boolean`, `symbol`, `null` and `undefined`. |
| 9 | +- Ist ein Wert eines primitiven Typs. |
| 10 | +- Es gibt 7 primitive Typen: `string`, `number`, `bigint`, `boolean`, `symbol`, `null` und `undefined`. |
11 | 11 |
|
12 | | -An object |
| 12 | +Ein Objekt |
13 | 13 |
|
14 | | -- Is capable of storing multiple values as properties. |
15 | | -- Can be created with `{}`, for instance: `{name: "John", age: 30}`. There are other kinds of objects in JavaScript: functions, for example, are objects. |
| 14 | +- Ist in der Lage, mehrere Werte als Eigenschaften zu speichern. |
| 15 | +- Kann erstellt werden mit `{}`, zum Beispiel: `{name: "John", age: 30}`. Es gibt noch weitere Arten von Objekten in JavaScript: Funktionen zum Beispiel sind Objekte. |
16 | 16 |
|
17 | | -One of the best things about objects is that we can store a function as one of its properties. |
| 17 | +Eines der größten Vorteile von Objekten ist, dass wir eine Funktion als eine ihrer Eigenschaften speichern können. |
18 | 18 |
|
19 | 19 | ```js run |
20 | 20 | let john = { |
21 | | - name: "John", |
22 | | - sayHi: function() { |
23 | | - alert("Hi buddy!"); |
24 | | - } |
| 21 | + name: 'John', |
| 22 | + sayHi: function () { |
| 23 | + alert('Hi Kumpel!'); |
| 24 | + }, |
25 | 25 | }; |
26 | 26 |
|
27 | | -john.sayHi(); // Hi buddy! |
| 27 | +john.sayHi(); // Hi Kumpel! |
28 | 28 | ``` |
29 | 29 |
|
30 | | -So here we've made an object `john` with the method `sayHi`. |
| 30 | +Hier haben wir also ein Objekt `john` mit der Methode `sayHi` erstellt. |
31 | 31 |
|
32 | | -Many built-in objects already exist, such as those that work with dates, errors, HTML elements, etc. They have different properties and methods. |
| 32 | +Es existieren bereits viele eingebaute Objekte, z. B. solche, die mit Daten, Fehlern, HTML-Elementen usw. arbeiten. Sie haben unterschiedliche Eigenschaften und Methoden. |
33 | 33 |
|
34 | | -But, these features come with a cost! |
| 34 | +Allerdings haben diese Besonderheiten auch ihren Preis! |
35 | 35 |
|
36 | | -Objects are "heavier" than primitives. They require additional resources to support the internal machinery. |
| 36 | +Objekte sind "schwerer" als Primitive. Sie brauchen zusätzliche Ressourcen, um die interne Funktionalität zu unterstützen. |
37 | 37 |
|
38 | | -## A primitive as an object |
| 38 | +## Ein Primitiv als Objekt |
39 | 39 |
|
40 | | -Here's the paradox faced by the creator of JavaScript: |
| 40 | +Hier ist das Paradoxon, mit dem sich der Erfinder von JavaScript auseinandersetzte: |
41 | 41 |
|
42 | | -- There are many things one would want to do with a primitive, like a string or a number. It would be great to access them using methods. |
43 | | -- Primitives must be as fast and lightweight as possible. |
| 42 | +- Es gibt viele Sachen, die man mit einem Primitiv wie einer Zeichenkette oder einer Zahl machen möchte. Es wäre hervorragend, wenn man auf sie in Form von Methoden zugreifen könnte. |
| 43 | +- Primitive müssen so schnell und leicht wie möglich sein. |
44 | 44 |
|
45 | | -The solution looks a little bit awkward, but here it is: |
| 45 | +Die Lösung sieht ein wenig umständlich aus, aber hier ist sie: |
46 | 46 |
|
47 | | -1. Primitives are still primitive. A single value, as desired. |
48 | | -2. The language allows access to methods and properties of strings, numbers, booleans and symbols. |
49 | | -3. In order for that to work, a special "object wrapper" that provides the extra functionality is created, and then is destroyed. |
| 47 | +1. Primitive sind nach wie vor primitiv. Ein einziger Wert, wie es sein soll.. |
| 48 | +2. Die Sprache ermöglicht den Zugriff auf Methoden und Eigenschaften von Zeichenketen, Zahlen, boolschen Werten und Symbolen. |
| 49 | +3. Damit das funktioniert, wird ein spezieller "Objekt-Wrapper" erstellt, der die zusätzlichen Funktionalitäten bereitstellt, und anschließend wieder zerstört wird. |
50 | 50 |
|
51 | | -The "object wrappers" are different for each primitive type and are called: `String`, `Number`, `Boolean`, `Symbol` and `BigInt`. Thus, they provide different sets of methods. |
| 51 | +Die "Objektwrappers" sind für jeden primitiven Typ unterschiedlich und heißen: `String`, `Number`, `Boolean` und `Symbol`. Daher stellen sie unterschiedliche Sätze von Methoden zur Verfügung. |
52 | 52 |
|
53 | | -For instance, there exists a string method [str.toUpperCase()](https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/String/toUpperCase) that returns a capitalized `str`. |
| 53 | +Es gibt zum Beispiel eine String-Methode [str.toUpperCase()](https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/String/toUpperCase) die ein großgeschriebenes `str` zurückgibt. |
54 | 54 |
|
55 | | -Here's how it works: |
| 55 | +Und so funktioniert's: |
56 | 56 |
|
57 | 57 | ```js run |
58 | | -let str = "Hello"; |
| 58 | +let str = 'Hallo'; |
59 | 59 |
|
60 | | -alert( str.toUpperCase() ); // HELLO |
| 60 | +alert(str.toUpperCase()); // HALLO |
61 | 61 | ``` |
62 | 62 |
|
63 | | -Simple, right? Here's what actually happens in `str.toUpperCase()`: |
| 63 | +Einfach, nicht wahr? Folgendes passiert tatsächlich in `str.toUpperCase()`: |
64 | 64 |
|
65 | | -1. The string `str` is a primitive. So in the moment of accessing its property, a special object is created that knows the value of the string, and has useful methods, like `toUpperCase()`. |
66 | | -2. That method runs and returns a new string (shown by `alert`). |
67 | | -3. The special object is destroyed, leaving the primitive `str` alone. |
| 65 | +1. Die Zeichenkette `str` ist ein Primitiv. Beim Zugriff auf ihre Eigenschaft wird also ein spezielles Objekt erstellt, das den Wert der Zeichenkette kennt und über nützliche Methoden verfügt, wie `toUpperCase()`. |
| 66 | +2. Diese Methode wird ausgeführt und gibt eine neue Zeichenkette zurück (angezeigt durch `alert`). |
| 67 | +3. Das spezielle Objekt wird zerstört, so dass das Primitiv `str` übrig bleibt. |
68 | 68 |
|
69 | | -So primitives can provide methods, but they still remain lightweight. |
| 69 | +Primitive können also Methoden bereitstellen, bleiben aber dennoch leichtgewichtig. |
70 | 70 |
|
71 | | -The JavaScript engine highly optimizes this process. It may even skip the creation of the extra object at all. But it must still adhere to the specification and behave as if it creates one. |
| 71 | +Die JavaScript-Engine optimiert dieses Verfahren erheblich. Es kann sogar sein, dass sie die Erstellung des zusätzlichen Objekts ganz überspringt. Sie muss sich aber trotzdem an die Spezifikation halten und sich so verhalten, als ob sie ein Objekt erstellt. |
72 | 72 |
|
73 | | -A number has methods of its own, for instance, [toFixed(n)](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toFixed) rounds the number to the given precision: |
| 73 | +Eine Zahl hat ihre eigenen Methoden, z. B. [toFixed(n)](https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Global_Objects/Number/toFixed) rundet die Zahl auf die vorgegebene Genauigkeit: |
74 | 74 |
|
75 | 75 | ```js run |
76 | 76 | let n = 1.23456; |
77 | 77 |
|
78 | | -alert( n.toFixed(2) ); // 1.23 |
| 78 | +alert(n.toFixed(2)); // 1.23 |
79 | 79 | ``` |
80 | 80 |
|
81 | | -We'll see more specific methods in chapters <info:number> and <info:string>. |
| 81 | +Wir werden weitere spezifische Methoden in den Kapiteln <info:number> und <info:string> sehen. |
82 | 82 |
|
| 83 | +````warn header="Konstrukteure `String/Number/Boolean` sind nur für den internen Gebrauch bestimmt Einige Sprachen wie Java erlauben es uns, explizit "Wrapper-Objekte" für Primitive zu erstellen, indem wir eine Syntax wie`new Number(1)`or`new Boolean(false)`. |
83 | 84 |
|
84 | | -````warn header="Constructors `String/Number/Boolean` are for internal use only" |
85 | | -Some languages like Java allow us to explicitly create "wrapper objects" for primitives using a syntax like `new Number(1)` or `new Boolean(false)`. |
| 85 | +In JavaScript ist das aus historischen Gründen auch möglich, aber höchst **nicht empfehlenswert**. Die Ergebnisse werden an mehreren Stellen verrückt. |
86 | 86 |
|
87 | | -In JavaScript, that's also possible for historical reasons, but highly **unrecommended**. Things will go crazy in several places. |
88 | | - |
89 | | -For instance: |
| 87 | +Zum Beispiel: |
90 | 88 |
|
91 | 89 | ```js run |
92 | | -alert( typeof 0 ); // "number" |
| 90 | +alert(typeof 0); // "number" |
93 | 91 |
|
94 | | -alert( typeof new Number(0) ); // "object"! |
| 92 | +alert(typeof new Number(0)); // "object"! |
95 | 93 | ``` |
96 | 94 |
|
97 | | -Objects are always truthy in `if`, so here the alert will show up: |
| 95 | +Objekte sind immer effektiv wahr in `if`, also wird hier alert angezeigt : |
98 | 96 |
|
99 | 97 | ```js run |
100 | 98 | let zero = new Number(0); |
101 | 99 |
|
102 | | -if (zero) { // zero is true, because it's an object |
103 | | - alert( "zero is truthy!?!" ); |
| 100 | +if (zero) { |
| 101 | + // zero ist wahr, weil es ein Objekt ist |
| 102 | + alert('zero ist effektiv wahr!?!'); |
104 | 103 | } |
105 | 104 | ``` |
106 | 105 |
|
107 | | -On the other hand, using the same functions `String/Number/Boolean` without `new` is totally fine and useful thing. They convert a value to the corresponding type: to a string, a number, or a boolean (primitive). |
| 106 | +Andererseits ist die Verwendung der selben Funktionen`String/Number/Boolean` ohne `new` eine völlig vernünftige und nützliche Sache. Sie konvertieren einen Wert in den entsprechenden Typ: in eine Zeichenkette, eine Zahl oder einen booleschen Wert (primitiv). |
108 | 107 |
|
109 | | -For example, this is entirely valid: |
| 108 | +Beispielsweise ist Folgendes durchaus zulässig: |
110 | 109 |
|
111 | 110 | ```js |
112 | | -let num = Number("123"); // convert a string to number |
| 111 | +let num = Number('123'); // konvertiert eine Zeichenkette zu einer Zahl. |
113 | 112 | ``` |
114 | | -```` |
| 113 | + |
| 114 | +````` |
115 | 115 |
|
116 | 116 |
|
117 | | -````warn header="null/undefined have no methods" |
118 | | -The special primitives `null` and `undefined` are exceptions. They have no corresponding "wrapper objects" and provide no methods. In a sense, they are "the most primitive". |
| 117 | +````warn header="null/undefined haben keine Methoden" |
| 118 | +Die speziellen Primitive `null` und `undefined` sind Ausnahmen. Sie haben keine entsprechenden "Wrapper-Objekte" und bieten keine Methoden. In gewissem Sinne sind sie "die primitivsten". |
119 | 119 |
|
120 | | -An attempt to access a property of such value would give the error: |
| 120 | +Ein Versuch, auf eine Eigenschaft mit einem solchen Wert zuzugreifen, würde diesen Fehler erzeugen: |
121 | 121 |
|
122 | 122 | ```js run |
123 | 123 | alert(null.test); // error |
124 | | -```` |
| 124 | +````` |
125 | 125 |
|
126 | | -## Summary |
| 126 | +## Zusammenfassung |
127 | 127 |
|
128 | | -- Primitives except `null` and `undefined` provide many helpful methods. We will study those in the upcoming chapters. |
129 | | -- Formally, these methods work via temporary objects, but JavaScript engines are well tuned to optimize that internally, so they are not expensive to call. |
| 128 | +- Primitive außer `null` und `undefined` verfügen über viele hilfreiche Methoden. Wir werden diese in den kommenden Kapiteln untersuchen. |
| 129 | +- Formal funktionieren diese Methoden über temporäre Objekte, aber JavaScript-Engines sind gut darauf abgestimmt, dies intern zu optimieren, so dass der Aufruf dieser Methoden nicht aufwendig ist. |
0 commit comments