Upgrade to Pro — share decks privately, control downloads, hide ads and more …

Per Anhalter durch JavaScript

Per Anhalter durch JavaScript

Viele Entwickler, die im Web arbeiten, programmieren auch JavaScript. Betonung auf “auch”: Ihre Hauptsprache und/oder Lieblingssprache ist wahrscheinlich eine andere. Gern wird JavaScript in “Geschmacksrichtung Java/Ruby…” geschrieben. Aber JS ist anders. Packt euer Handtuch ein: Wir nehmen euch mit auf eine Reise ins JavaScript-Universum, um euch diese seltsame und tolle Sprache und seine Besonderheiten näherzubringen und euch zu helfen, JavaScript zu schreiben, wie es geschrieben werden möchte.

Lucas Dohmen

January 23, 2020
Tweet

More Decks by Lucas Dohmen

Other Decks in Programming

Transcript

  1. Per Anhalter durch JavaScript 2 3 . 0 1 .

    2 0 2 0 D ü s s e l d o r f, G e e k t a s t i c C o n n e c t
  2. 3 Design 1. Brendan mochte gerne Scheme und Self 2.

    Marketing-Abteilung wollte Ähnlichkeit zu Java 3. Es sollte einfach zu benutzen sein, auch für Nicht- Programmierer 4. Er hatte nur 10 Tage Zeit So hot right now
  3. 5 “The ECMAScript runtime system performs automatic type conversion as

    needed.” ECMAScript 2018 Language Specification, 7.1 Type Conversion
  4. Es sieht so aus als würdest du einen String brauchen.

    Ich hab ihn für dich konvertiert. Klarer Fall, du willst eine Zahl*! * 'hello' als Zahl ist NaN '' als Zahl ist 0
  5. 8 Die Wahrheit ist irgendwo da draußen Alles wird zu

    true umgewandelt außer false, null, undefined, 0, NaN, ""
  6. 10 JavaScript versucht für dich Dinge in den richtigen Typen

    zu verwandeln. Dabei stellt es sich nicht immer klug an.
  7. 11 Folglich •Immer === statt == benutzen – hier passiert

    keine Typkonvertierung •Bei Gleichheit zudem beachten: Primitive Werte werden anhand ihres Wertes verglichen, Objekte anhand ihrer Identiät •Was ist ein Objekt? Dazu nun mehr.
  8. 15 Objekte •Ein Objekt ist ein Dictionary •Die Schlüssel sind

    immer Strings •Die Werte können beliebige Typen haben •Ist der Schlüssel kein String, wird toString() darauf aufgerufen: •lisa.toString() === '[object Object]' •lucas.toString() === '[object Object]' •lisa.toString() === lucas.toString()
  9. 18 Fast alles ist ein Objekt •Primitive Values: Undefined, Null,

    Boolean, Number, String, Symbol •Alles andere sind Objekte, zB.: •Arrays •Reguläre Ausdrücke •Promises •Funktionen •...
  10. You can think of a prototype as a “hidden” property

    on every object that determines “where to look next”. So if there’s no taste property on iceCream, JavaScript will look for a taste property on its prototype, then on that object’s prototype, and so on, and will only give us undefined if it reaches the end of this “prototype chain” without finding .taste Dan Abramov 22
  11. 27 Objekte sind Dictionaries die Strings auf beliebige Objekte abbilden

    und alle nicht definierten Schlüssel an die Prototypenkette weitergeben. Wird nichts gefunden, wird undefined zurückgegeben.
  12. „Seht mich an. Ein Hirn von der Größe eines Planeten,…

    und man schickt mich, um euch in die Kommandozentrale zu bringen. Nennt man das vielleicht berufliche Erfüllung? Also ich nicht.“ 33
  13. 39 Definition Mit Hoisting (engl., Hochziehen) bezeichnet man das Verhalten

    des JavaScript-Interpreters bei der Deklaration von Variablen und Funktionen. Wikipedia 
 21.01.20, https://de.wikipedia.org/wiki/Hoisting
  14. let -> kein Hoisting, Text 43 In ECMAScript 2015, werden

    Deklarationen mit let nicht an den Anfang des Blocks verschoben (hoist). MDN 
 22.01.20, https://developer.mozilla.org/de/docs/Web/JavaScript/Reference/Statements/let
  15. 54 „Das hier ist 'ne verdammt harte Galaxis. Wenn man

    hier überleben will, muss man immer wissen, wo sein Handtuch ist!“
  16. 55 Projekt aufsetzen 1. editorconfig 2. prettier 3. ESLint 4.

    Testing 5. NPM scripts 6. Ein paar Tipps zum Client/Server
  17. 57 prettier •Plug-in für die meisten Editoren/IDEs •Automatisches Code Formatting

    (zB. beim Speichern) •auch für TypeScript, (S)CSS... •Keine* Config, beachtet die editorconfig ˰
  18. 58 ESLint •Plug-in für die meisten Editoren/IDEs •Feedback zu häufigen

    Fehlern •Hochkonfigurierbar •Kann mit Prettier zusammenarbeiten
  19. 59 Testing •Eine riesige Auswahl an Testing Tools •Die meisten

    sind okay •In jedem Projekt ein neues Testing Tool...
  20. 60 NPM scripts •Der einfachste Task Runner: •Name, Shell Script

    •npm run test (bzw. npm t) •Kann auf CI ausgeführt werden
  21. Krischerstr. 100 40789 Monheim am Rhein Germany +49 2173 3366-0

    Ohlauer Str. 43 10999 Berlin Germany +49 2173 3366-0 Ludwigstr. 180E 63067 Offenbach Germany +49 2173 3366-0 Kreuzstr. 16 80331 München Germany +49 2173 3366-0 Hermannstrasse 13 20095 Hamburg Germany +49 2173 3366-0 Gewerbestr. 11 CH-6330 Cham Switzerland +41 41 743 0116 innoQ Deutschland GmbH innoQ Schweiz GmbH www.innoq.com 62 Danke! Fragen? Lucas Dohmen [email protected] +49 151 75062496 moonbeamlabs Lisa Maria Moritz [email protected] +49 176 646 300 28 teapot4181