css mit Adi Prinz

Variablen

JavaScript-Variablen können Werte für eine spätere Verwendung speichern. Der Zugriff auf eine Variable ist abhängig vom Ort der Deklaration (wo wird die Variable geschrieben) bzw. mit welchem Schlüsselwort wurde die Variable deklariert. Folgende Schlüsselworter gibt es:

  • var (z.B. var x = "Hallo Welt";)
  • let (z.B. let y= "Hallo Welt";)
  • const (z.B. const z = "Hallo Welt";)

JavaScript kennt drei Gültigkeitsbereiche (Scope) von Variablen nämlich:

  • Block scope
  • Function scope
  • Global scope

Mehr Informationen über Variablen Scope finden sie im Kapitel Funktionen.

Variablendeklaration

Variablen werden mit dem Schlüsselwörtern var, let oder const definiert. Dem Schlüsselwort folgt ein Bezeichner und optional kann der Variablen ein Wert zugewiesen werden.

let x;
let y = 'Hallo ';
x = 'Welt';
let z = y + x;
console.log(z);

Theorethisch kann man eine Variable ohne Schlüsselwort deklarieren. Diese Deklaration zählt allerdings zu schlechtem Programmierstil und kann sogar zu Konflikten im Programmcode führen.

Eine Deklaration für viele Variablen

Mehrere Javascript-Variablen können auch in einem Ausdruck deklariert werden. Als Trennzeichen wird das Komma verwendet.

let vorName = "Adi", nachName = "Prinz", alter = 60;
console.log(nachName);

Oder Mehrzeilig.

let vorName = "Adi", 
    nachName = "Prinz", 
    alter = 60;
console.log(vorName);

Verwenden sie die Browser-Konsole um JavaScript Code auf dieser Seite zu testen.

Gültikeitsbereiche für Variablen (Scope)

Block Scope

Auf let-Variablen und const-Konstanten, die innerhalb eines Blocks { } deklariert sind, kann nicht von außerhalb des Blocks zugegriffen werden:

{
  let x = 2;
}
console.log(x);

{
  const y = "Hallo Welt";
}
console.log(y);

Auf var-Variablen, die innerhalb eines Blocks { } deklariert sind, kann auch von außerhalb des Blocks zugegriffen werden:

{
  var x = 2;
}
console.log(x);

Function Scope

Mit var, let und const deklarierte Variablen sind ziemlich ähnlich, wenn sie innerhalb einer Funktion deklariert werden.
Jede Funktion erstellt einen neuen Gültigkeitsbereich. Innerhalb einer Funktion deklarierte Variablen sind von außerhalb der Funktion nicht sichtbar.

function myFunction() {
  var x = "Auto";   // Function Scope
  let y = "Fahrrad";   // Function Scope
  const z = "Motorrad";   // Function Scope
}
console.log(x);
console.log(y);
console.log(z);

Global Scope

Eine Variable die außerhalb einer Funktion oder eines Blocks deklariert wurde ist GLOBAL.

var x = "Auto";   // Global Scope
let y = "Fahrrad";   // Global Scope
const z = "Motorrad";   // Global Scope

function myFunction() {
return x + y + z;
}
myFunction();

Wie setze ich Schlüsselworter in Variablen ein?

Wenn Sie eine allgemeine Regel wollen deklarieren Sie Variablen immer mit const.
Wenn Sie glauben, dass sich der Wert der Variablen ändern kann, verwenden Sie let.

Beispiel

const x = 2;
x = 3; // Das ist nicht möglich
const x = 4; // Das ist nicht möglich
let y = 2;
y = 3; // Das ist möglich
let y = 4; // Das ist nicht möglich
var z = 2;
var z = "Hallo"; // Das ist möglich
z = "Welt"; // Das ist möglich
a = 5; // Das ist im strict-modus nicht erlaubt
  • const-Variablen sind eigentlich Konstanten. Eine erneute Deklaration ist nicht erlaubt. Die Werte-Zuweisung kann nicht geändert werden.
  • let-Variablen können nicht neu deklariert werden. Die Werte-Zuweisung kann geändert werden.
  • var-Variablen können neu deklariert werden. Die Werte-Zuweisung kann geändert werden.

Vermeiden Sie Variablendeklarationen mit dem Schlüsselwort var!
Definieren Sie niemals Variablen ohne Schlüsselwort!

Datentypen

Eine JavaScript-Variabel kann jeden bekannten Datentyp aufnehmen. Alle Werte in JavaScript verhalten sich wie Objekte, aber strenggenommen gibt es einen Unterschied zwischen Objekten und einfachen Werten.

JavaScript kennt 8 Datentypen

  • String
  • Number
  • Boolean
  • Undefined
  • Null
  • Object
  • Symbol
  • Bigint

Primitive Werte in Variablen

Einfache Werte werden auch Primitive Values oder Primitives genannt. Primitives sind Datentypen die kein Objekt sind und daher auch keine Methoden oder Eigenschaften haben.

  • Text: Textwerte werden immer in einfache oder doppelte Anführunszeichen geschrieben, Text wird in den Programmiersprachen auch String genannt (Zeichenkette)
  • Zahl: Ganzzahlige Werte oder Zahlen mit Komma, Achtung: Punkt als Komma (1.5), der Datentyp Zahl wird in JavaScript Number genannt
  • Boolean: Wahrheitswerte true oder false
  • null: der Wert Nichts
  • undefined: Rückgabewert einer Variablen ohne Zuweisung

Der Datentyp object

Der Datentyp object kann folgendes enthalten:

  • Ein object
  • Ein array
  • Ein date(Datum)

Objekte, Funktionen und Arrays wird ein eigenes Kapitel gewidmet!

String

Textwerte werden in JavScript in Anführungszeichen gestellt. Das können einfache ('') oder doppelte ("") sein (double or single quotes).

let x = "Das ist Text";
let y = 'Das auch';

Wenn jetzt ein Anführungszeichen im Text vorkommen soll, kann man alternative Anführungszeichen schreiben:

let x = "Mein Name ist 'Hase', ich weiß von Nichts"; 
// oder so:
let x = 'Mein Name ist "Hase", ich weiß von Nichts';

Auch mit dem Escape-Zeichen (\) oder Backslash können Anführungszeichen im Text notiert werden. Man muß einfach den Backslash vor das Anführungzeichen stellen.

var x = "Mein Name ist \"Hase\", ich weiß von Nichts"; 

Mit dem Escape-Zeichen (\) können noch weitere Zeichen im Text geschrieben werden:

Code Rückgabe
\' Einfache Anführungszeichen
\" Doppelte Anführungszeichen
\\ Backslash
\n Zeilenumbruch
\r Wagenrücklauf
\t Tabstopp
\b Backspace
\f Seitenvorschub

Achtung bei mehrzeiligen Wertzuweisungen. Ein Ausdruck wie der folgende wird wahrscheinlich nicht den gewünschten Effekt erzielen:

let x = "Hallo
        Welt";
console.log(x);

In diesem Fall müssen sie mit dem String-Operator (+) eine Verkettung herstellen.

let x = "Hallo " +
        "Welt";
console.log(x);

Number

Während andere Programmiersprachen unterschiedliche Zahlentypen kennen (integer, double etc), existiert in JavaSript nur einer, nämlich number. Numbers können mit oder ohne Dezimalstellen geschrieben sein, achten sie jedoch auf den Punkt als Kommazeichen (amerikanisches Zahlenformat).

let x = 5;
let y = 3 * 4;
let z = 3.14;

Numbers können auch wissenschaftliche- bzw. hexadezimale Werte sein.

let x = 0xFF;   // 255
let y = 123e5;  // 12300000

Boolean

Booleanische Datentypen können zwei Werte aufnehmen true oder false (WAHR oder FALSCH).

let a = true; // liefert true
let b = 10 > 2 * 5;  // liefert false
let c = 10 == 2 * 5; // liefert true
console.log(a);
console.log(b);
console.log(c);

Primitive Values wie String, Number und Boolean können auch Objekte sein. Mehr darüber erfahren sie im Kapitel Vordefinierte Objekte. Den Objekten Arrays, Funktionen und Objekte werden eigene Kapitel gewidmet.

Null

Null bedeutet soviel wie Nichts und wird zum Leeren von Variablen verwendet. Bei der typeof-Anweisung liefert null Object als Wert.

let x = 10;
x = null;
console.log(x);

Undefined

Undefined sind Variablen ohne Wert. Bei der typeof-Anweisung liefert undefined undefined als Wert.

let x;
let y = undefined;
console.log(typeof(x)); //undefined
console.log(typeof(y)); //undefined

typeof

Mit dem Operator typeof können Sie den Variablentyp eines Ausdrucks ermitteln. Er wird dem Operanden vorangestellt, bei dem es sich um einen beliebigen Ausdruck handeln kann. Abhängig vom Ergebnis der Auswertung des Operanden wird ein String zurückgegeben, der den Bezeichner des entsprechenden Datentyps enthält.

let x = "Hallo Welt";
console.log(typeof(x)); //string
console.log(typeof(3 + 2)); //number
console.log(typeof(true)); //boolean

Operatoren

Wenn innerhalb eines JavaScript-Programms einer Variablen ein Wert zugewiesen wird, wenn Werte, Variablen oder Eigenschaften von Objekten miteinander verglichen, verkettet, berechnet werden, dann geschieht dies durch Operatoren. Programmiersprachen teilen Operatoren in Gruppen auf:

  • Arithmetische Operatoren (Rechenoperatoren)
  • Zuweisungsoperatoren
  • Der String-Operator
  • Vergleichsoperatoren
  • Logische Operatoren
  • Conditional Operator
  • Spezielle Operatoren

Arithmetische Operatoren

Berechnungen werden mit Arithmetische Operatoren durchgeführt. Es gelten die Regeln der Mathematik (Punkt vor Strich usw.) Auch Klammern stehen zur Verfügung.

let x = 3;
let y = 4; 
let z = 5;
let a = (x + y) * z;
console.log(a);

Liste der Arithmetische Operatoren

Operator Beschreibung Beispiel
+ Addition x = 2 + 3
- Subtraktion x = 5 - 4
* Multiplikation x = 3 * 3
/ Division x = 9 / 3
% Modulo x = 9 % 3
++ Inkrement x = 1++
-- Dekrement x = 2++

Zuweisungsoperatoren

Einer Variablen wird mit dem Gleichheitszeichen ein Wert zugewiesen ( x = 2 + 2). Gleichheitszeichen können auch mit Rechenoperatoren kombiniert werden..

let x = 3;
x += 5;
// oder
x = x + 5;

Liste der Zuweisungsoperatoren

Operator Beispiel Alternativ
= x = y x = y
+= x += 1 x = x + y
-= x -= y x = x - y
*= x *= y x = x * y
/= x /= y x = x / y
%= x %= y x = x % y

Der String-Operator

Der String-Operator wird in Textverarbeitungsprogrammen auch Verkettungsoperator genannt. Dafür verwendet JavaScript das mathematische Plus (+).

let x = "Adi";
let y = "Prinz"
let z = x + " " + y;
console.log(z);

String-Operator

Operator Beispiel Resultat
+ "5" + 5 55

Vergleichsoperatoren

Vergleichsoperatoren können zwei- oder mehrere Werte vergleichen. Der Rückgabewert solcher Anweisungen kann nur true oder false sein. In der Tabelle gehen wir davon aus, dass x den Wert 5 hat.

let x = 5;

Liste der Vergleichsoperatoren

Operator Beschreibung Vergleich Wert
== Gleichheit x == "5" true
=== Gleicher Wert und Datentyp x === "5" false
!= Ungleich x != "5" false
!== Ungleicher Wert und Datentyp x !== "5" true
Größer als x > 8 false
Kleiner als x < 8 true
>= Größer oder Gleich als x >= 8 false
<= Kleiner oder Gleich als x <= 8 true

Das nächste Beispiel liefert false weil 5 vom Datentyp Number und "5" vom Datentyp String ist.

let x = 5;
console.log(x === "5"); // liefert false

Logische Operatoren

Als kleine Hilfe kann man sich bei logischen Operatoren die EXCEL-Funktionen UND, ODER, NICHT vorstellen.

  • Der logische Operator && verknüpft zwei oder mehrere Bedingungen durch UND, WAHR ist wenn alle Bedingungen erfüllt sind (true)
  • Der logische Operator || verknüpft zwei oder mehrere Bedingungen durch ODER, WAHR ist wenn eine der Bedingungen erfüllt ist (true)
  • Der logische Operator ! prüft zwei Bedingungen auf WAHR oder FALSCH, und wandelt den Wert um: Aus WAHR wird FALSCH und umgekehrt

In der Beispieltabelle gehen wir davon aus, dass x den Wert 10 und y den Wert 5 hat.

let x = 10;
let y = 5;

Liste der Logischen Operatoren

Operator Beschreibung Beispiel Resultat
&& and (x < 10 && y > 1) false
|| or (x == 5 || y == 5) true
! not !(x == y) true

Conditional Operator

Der conditional-Operator oder auch bedingter-Operator bestimmt eine Zuweisungen abhängig von der Prüfung.

let y = 100;
let x = (y >= 100) ? "Große Zahl" : "Kleine Zahl";
console.log(x); // liefert Große Zahl

Die Prüfung lautet: (y >= 100), danach kommt ein Fragezeichen, danach der Dann-Wert und der Sonst-Wert getrennt mit einem Doppelpunkt. Anhand der Prüfung entscheidet JavaScript den Rückgabewert. Eigentlich ist der bedingte Operator eine verkürzte if-then-else-Anweisung. Die Syntax sieht wie folgt aus:

(Bedingung) ? Ausdruck : Ausdruck;

Spezielle Operatoren

Neben den oben angeführten Operatoren gibt es auch noch die Gruppe der speziellen Operatoren, die hier nur kurz aufgelistet werden.

Der typeof-Operator

Der typeof-Operator gibt den Typ von Variablen, Objekten, Funktionen oder Ausdrücken zurück:

  • typeof "Adi Prinz" // string
  • typeof 5.50 // number
  • typeof NaN // number
  • typeof false // boolean
  • typeof [1, 2, 3, 4] // object
  • typeof {name:'Adi', age:60} // object
  • typeof new Date() // object
  • typeof function () {} // function
  • typeof x // undefined (wenn x nicht deklariert ist)
  • typeof null // object
  • Datentypen wie Arrays, Date und Null liefern object
  • Der Datentyp undefined ist eine nicht definierte Variable
  • Der Datentyp von NaN liefert number

Der delete-Operator

Der delete-Operator löscht Eigenschaften eines Objekts. Variablen und Funktionen können mit dem delete-Operator nicht gelöscht werden.

let person = {firstName:"Adi", lastName:"Prinz", age:60};
delete person.age;   // oder delete person["age"]; 

Auch Array-Einträge können gelöscht werden.

let script = ["HTML", "CSS", "JavaSript", "PHP"];
delete script[0];   

Der in-Operator

Der in-Operator liefert true wenn eine angegebene Eigenschaft eines Objekt exisitert, sonst false.

// Arrays
let script = ["HTML", "CSS", "JavaSript", "PHP"];
console.log(0 in script);  // liefert true

// Objects
let person = {firstName:"Adi", lastName:"Prinz", age:60};
console.log("firstName" in person); // liefert true

// Vordefinierte Objekte
console.log("PI" in Math); // liefert true

Der instanceof-Operator

Der instanceof-Operator liefert true wenn das angegebene Objekt vom angegebenen Typ ist, sonst false.

let script = ["HTML", "CSS", "JavaSript", "PHP"];
script instanceof Array;  // true
script instanceof Object; // true
script instanceof String; // false

Der void-Operator

Der void-Operator führt die nach ihm geschriebene Anweisung aus. Der Rückgabewerte dieser Anweisung ist stets undefined.

let x = 1;
let y = 2;
let z = void(x + y)
console.log(z); // liefert undefined