diff --git a/src/components/slides/javascript/01-control-flow/if-else.astro b/src/components/slides/javascript/01-control-flow/if-else.astro
new file mode 100644
index 0000000..d21730b
--- /dev/null
+++ b/src/components/slides/javascript/01-control-flow/if-else.astro
@@ -0,0 +1,110 @@
+ In JS ist das if-else Konstrukt das gleiche wie in vielen anderen Sprachen Die Hier kommt nun zum ersten mal einer der Features von JS zu tragen, die manchmal zu skurillen Ergebnissen führt: Implicit Type Conversion In bestimmten Fällen erwartet JavaScript einen bestimmten Datentyp. Wird ein anderer Datentyp angefunden, so versucht JavaScript den Wert in den benötigten Datentyp zu konvertieren ohne dass der Entwickler explizit eine Konversion durchführen muss. Die Konversion geschieht nahtlos zwischen verschiedenen Typen Im Fall einer Boolean-Conversion sprechen wir darüber, ob ein Wert/Datentyp einen truthy oder falsy Wert hat. Falsy Werte Wir können eine Variable "explizit" zu einem Boolean konvertieren, indem wir ein doppeltes Ausrufezeichen ( Ein einfaches Ausrufezeichen konvertiert den Wert auch in ein Boolean, führt aber eine Not-Operation aus. (Im Grunde wenden wir ein Not-Not mit dem doppelten Ausrufezeichen an) Werte miteinander Vergleichen Eine weitere Besonderheit in JS: Es gibt 2 "Arten" um eine Gleicheit festzustellen. Hierfür gibt es den "einfach" Vergleichsoperator Der Unterschied zwischen Ein Beispiel Der Richtige Ansatz hierbei ist: Verwenden sie den Typ-Sicheren Vergleichsoperator Weitere Vergleichsoperationen Es können mehrere Vergleiche durchgeführt werden und mit UND / ODER verknüpft werden:If - Else Statements
+
+
+ if (/* Condition */) {
+
+ } else if (/* Condition */) {
+ // Es können weitere else-if cases hinzugefügt werden
+ } else {
+ // "Everything else"
+ }
+
Conditionals
müssen natürlich einem wahren oder falschen Wert (Boolean) entsprechen.
+
+ let num = 5;
+ if (num) {
+ console.log('Num ist true!');
+ }
+ num = 0;
+ if (num) {
+ console.log('Num ist immernoch true?');
+ } else {
+ console.log('Num ist false!');
+ }
+
+
+ !!
) vor die Variable stellen
+
+ let num = 5;
+ const isTruthyNum = !!num;
+
==
und einen sicheren Vergleichsoperator ===
== & ===
liegt darin, dass beim einfachen Vergleich, JavaScript unter Umständen den Datentypen konvertiert um Gleichheit zu testen.
+
+ const theAnswer = 42;
+ if ("42" == theAnswer) {
+ console.log('Yay');
+ }
+ if ("42" === theAnswer) {
+ // Wird nicht gelogged
+ console.log('No Yay');
+ }
+
"==="
+
+
+
+
Alle bekannten Schleifen die man wahrscheinlich aus anderen Programmiersprachen kennt, gibt es auch in JS
+Die Syntax ist auch der zu C oder Java sehr ähnlich / gleich
+
+ // Kopfgesteuert
+ while (/* Condition */) { /* Code to Execute */ }
+
+ // Fußgesteuert
+ do { /* Code to Execute */} (/* Condition */)
+
+ // Zählschleife
+ // for (init; condition; "afterthought")
+ for (let i = 0; i < 5; i++) {
+ /* Code to Execute */
+ }
+
+ Eine Realität aus meiner Sicht als Webentwickler:
+Ich verwende Schleifen in dieser Form nur noch sehr selten.
+Wenn wir mit Arrays und dergleichen Arbeiten, gibt es bereits eine Menge an "Convenience"-Features, die wir verwenden können um über alle Inhalte eines Arrays zu iterrieren / manipulieren / testen.
+Auch in JavaScript haben wir die Möglichkeit mehrere Möglichkeiten einer Variable abzufragen.
+
+ const num = 42;
+ switch (num) {
+ case 1:
+ break;
+ case 42:
+ // Code hier wird ausgeführt
+ break;
+ default:
+ // Falls kein 'case' matched
+ }
+
+ Es gibt leider keine Möglichkeit Funktionsaufrufe zum testen zu machen, hierfür müssen andere Optionen in Erwägung gezogen werden.
+