TypeScript
TypeScript | |
---|---|
Basisdaten | |
Paradigmen: | funktional, imperativ, objektorientiert (Prototypen, Klassen), strukturiert, skripting |
Erscheinungsjahr: | 2012 |
Designer: | Microsoft |
Entwickler: | Anders Hejlsberg, Microsoft |
Aktuelle Version | 5.5.3[1] (2. Juli 2024) |
Typisierung: | stark, schwach, duck, dynamisch, statisch, explizit, implizit |
Beeinflusst von: | JavaScript, Java, C# |
Lizenz: | Apache-Lizenz |
www.typescriptlang.org |
TypeScript ist eine von Microsoft entwickelte Skriptsprache, die auf den Vorschlägen zum ECMAScript-6-Standard[2] basiert und statische Typisierung zu JavaScript hinzufügt. Sprachkonstrukte von TypeScript, wie Klassen, Vererbung, Module und anonyme Funktionen, wurden auch in ECMAScript 6 übernommen.[3]
TypeScript ist eine echte Obermenge (strict superset) von JavaScript bzw. ECMAScript 2015. Jeder JavaScript-Code ist daher auch gültiger TypeScript-Code, so dass gängige JavaScript-Bibliotheken (wie z. B. jQuery oder Angular) auch in TypeScript verwendet werden können.[3]
TypeScript unterstützt mit Modulen das Kapseln von Klassen, Interfaces, Funktionen und Variablen in eigene Namensräume. Dabei wird zwischen internen und externen Modulen unterschieden. Interne Module lehnen sich an die Modul-Spezifikation aus ECMAScript 6 an, wohingegen externe Module eine JavaScript-Bibliothek (AMD oder CommonJS) nutzen.[4]
Der von Microsoft entwickelte TypeScript-Compiler transkompiliert TypeScript-Code nach ECMAScript 5 (ES5), optional auch nach ECMAScript 3 (ES3).
TypeScript kann mit Hilfe von Plug-ins in verschiedene Build-Management-Tools integriert werden, darunter Grunt (grunt-ts[5]), Apache Maven (TypeScript Maven Plugin[6]) und Gradle (TypeScript Gradle Plugin[7]).
Geschichte
[Bearbeiten | Quelltext bearbeiten]Die erste öffentlich verfügbare Version von TypeScript wurde 2012 nach zwei Jahren Entwicklung von Microsoft in der Version 0.8 veröffentlicht.[8][9] Kurz nach Ankündigung der Sprache wurde diese von Miguel de Icaza gelobt. Jedoch bemängelte er, dass es keine weiteren Entwicklungsumgebungen abseits von Microsoft Visual Studio gab, das 2013 nicht für Linux und macOS zur Verfügung stand.[10][11] Seit 2013 gab es Plugin-Support für Eclipse, der von Palantir Technologies bereitgestellt wurde.[12][13] Mittlerweile unterstützen eine Vielzahl von Texteditoren und Entwicklungsumgebungen TypeScript. Darunter befinden sich Emacs, vim, Sublime Text[14], WebStorm, Atom[15] und Microsofts eigener Editor Visual Studio Code.
TypeScript 0.9 wurde 2013 veröffentlicht und brachte Unterstützung für generische Typen.
TypeScript 1.0 wurde 2014 auf Microsofts hauseigener Entwicklerkonferenz Build vorgestellt.[16] Auch erhielt Visual Studio Unterstützung für TypeScript.[17]
Im Juli 2014 kündigten die Entwickler von TypeScript einen neuen Compiler an, der fünfmal schneller sein sollte als der alte. Gleichzeitig wurde der bisherige Quellcode von TypeScript von CodePlex zu GitHub migriert.[18]
Am 22. September 2016 wurde die Version 2.0 veröffentlicht, die diverse neue Funktionen einführte. Unter anderem wurde eine optionale Funktion eingeführt, um zu verhindern, dass Variablen standardmäßig mit null
initialisiert sind.[19] Dies soll zu weniger Nullpointer Exceptions führen.
Am 30. Juli 2018 wurde die Version 3.0 veröffentlicht. Besonders hervorzuheben ist der neue primitive Typ unknown
. Zusammen mit void
(dem Einheitstyp) und never
(dem leeren Typ) vervollständigt er die Ränder der Typenhierarchie: unknown
ist ein Universaltyp; einer Variable davon kann jedes Objekt zugewiesen werden, und entsprechend kann man von einem unknown
-Wert nichts erwarten. TypeScript verlangt dann eine Assertion oder Checks. Im Unterschied dazu ist any
zwar auch ein Universaltyp, jedoch erlaubt TypeScript die Verwendung der Werte direkt, obwohl eigentlich keine Information darüber vorliegt. Damit ist unknown
nichts anderes als das typsichere Äquivalent zu any
.
Features
[Bearbeiten | Quelltext bearbeiten]TypeScript erweitert die Sprache ECMAScript 6 um folgende Merkmale:
- Methodensignatur
- Typinferenz
- Type Erasure
- Interfaces
- Aufzählungstyp
- Generische Programmierung
- Namensräume
- Tupel
- Async/Await
Folgende Elemente wurden durch einen Backport von ECMAScript 2015 hinzugefügt:
- Klassen
- Module[20]
- Arrow-Syntax für anonyme Funktionen
- Optionale Parameter und Standardparameter
Kompatibilität mit JavaScript
[Bearbeiten | Quelltext bearbeiten]TypeScript ist eine Obermenge von ECMAScript 2015, das selbst eine Obermenge von ECMAScript 5 ist, was oft in Referenz mit JavaScript gestellt wird.[21] Ein JavaScript-Programm ist somit auch ein valides TypeScript-Programm. Somit kann TypeScript ohne Probleme JavaScript verwenden. Der Compiler benutzt normalerweise ECMAScript 5, aber es besteht auch die Möglichkeit, Konstrukte von ECMAScript 3 oder 2015 zu verwenden.
TypeScript bietet die Möglichkeit an, existierenden JavaScript-Code und bekannte JavaScript-Bibliotheken zu verwenden.[22]
Methodensignatur
[Bearbeiten | Quelltext bearbeiten]TypeScript bietet Methodensignaturen an, die das Überprüfen von Methoden während der Kompilierung ermöglichen. Dies ist optional und kann ignoriert werden.
function add(left: number, right: number): number {
return left + right;
}
Die Annotationen für die primitiven Typen sind number
, boolean
und string
.
Klassen
[Bearbeiten | Quelltext bearbeiten]TypeScript unterstützt ECMAScript-2015-Klassen[23], die optionale Methodensignaturen verwenden können:
class Person {
private name: string;
private age: number;
private salary: number;
constructor(name: string, age: number, salary: number) {
this.name = name;
this.age = age;
this.salary = salary;
}
toString(): string {
return `${this.name} (${this.age}) (${this.salary})`; // As of version 1.4
}
}
Generische Programmierung
[Bearbeiten | Quelltext bearbeiten]TypeScript unterstützt Generische Programmierung.[24] Das ist ein Beispiel einer Identitätsfunktion:[25]
function doSomething<T>(arg: T): T {
return arg;
}
Union-Typen
[Bearbeiten | Quelltext bearbeiten]Union-Typen werden in TypeScript unterstützt.[26] Es können insbesondere auch komplexe Typen als sogenannte Tagged Union Types[27] definiert werden.
function successor(n: number | bigint): number | bigint {
return ++n;
}
Module und Namespaces
[Bearbeiten | Quelltext bearbeiten]TypeScript unterscheidet zwischen Modulen und Namespaces. Beide Features in TypeScript unterstützen die Kapselung von Klassen, Schnittstellen, Funktionen und Variablen in Containern. Namespaces (ehemals interne Module) verwenden sofort aufgerufene Funktionsausdrücke von JavaScript, um Code zu kapseln, während Module (ehemals externe Module) JavaScript-Bibliotheksmuster nutzen, um dies zu tun (AMD oder CommonJS).[28]
Design
[Bearbeiten | Quelltext bearbeiten]TypeScript stammt von der Skriptsprache JavaScript ab und will dessen Mängel im Bereich der Entwicklung von großen Applikationen beheben, was von Microsoft selbst veranlasst wurde.[29] Die Herausforderung, mit dem komplexen Code von JavaScript umzugehen, führte dazu, dass ein dafür angepasstes Werkzeug zur Vereinfachung der Entwicklung dieser Komponenten erstellt wurde.[30]
Die Entwickler von TypeScript suchten eine Lösung, die nicht die Kompatibilität mit dem Standard oder die Plattformunabhängigkeit von JavaScript gefährdet. Mit dem Wissen, dass ECMAScript in Zukunft das klassenbasierte Programmieren unterstützen wollte, wurde TypeScript auf diesem Grundsatz entwickelt. Das führte zu einem JavaScript-Compiler mit einigen Erweiterungen, die den Code in JavaScript übersetzen.
TypeScript fügte die Unterstützung des ECMAScript-2015-Standards hinzu.
Versionsgeschichte
[Bearbeiten | Quelltext bearbeiten]Versions- nummer |
Veröffentlichungs- datum |
Änderungen |
---|---|---|
0.8 | 1. Oktober 2012 | Erste Veröffentlichung |
0.9 | 18. Juni 2013 | Generische Ausdrücke, Überladen von konstanten Parametern, Enum[31] |
1.1 | 6. Oktober 2014 | Performanceverbesserungen |
1.3 | 12. November 2014 | protected Zugriffsmodifikator, Tupel-Typen
|
1.4 | 20. Januar 2015 | Union-Typen, let und const Deklarationen, Template Strings, Type Guards, Type Aliases
|
1.5 | 20. Juli 2015 | ES6-Module, namespace Keyword, for..of Support, Decorator
|
1.6 | 16. September 2015 | JSX-Unterstützung, Intersection Typen, lokale Typdeklarationen, abstrakte Klassen und Methoden, benutzerdefinierte Guard-Funktionen |
1.7 | 30. November 2015 | Unterstützung für async und await [32]
|
1.8 | 22. Februar 2016 | Constraints Generics, Kontrollfluss-Fehleranalyse, Stringliteral-Typen, allowJs
|
2.0 | 22. September 2016 | null - und undefined -verhindernde Typen, kontrollflussbasierte Typanalyse, Discriminated Uniontypen, never Typ, readonly Keyword, this
|
2.1 | 8. November 2016 | keyof und Lookup Typen, gemappte Typen, REST- und Spread-Eigenschaften für Objekte
|
2.2 | 22. Februar 2017 | Mix-in Klassen, object Typ
|
2.3 | 27. April 2017 | async Iteration, generische Standardparameter, strict-Option
|
2.4 | 27. Juni 2017 | dynamische import Ausdrücke, String Enums, verbesserte Vererbung für generische Datentypen, strikte Kontravarianz für Callback-Parameter
|
2.5 | 31. August 2017 | optionale Catch-Clause-Variablen für Exceptions |
2.6 | 31. Oktober 2017 | strikte Funktionstypen |
2.7 | 31. Januar 2018 | const -benannte Eigenschaften, Tupel mit fester Länge
|
2.8 | 27. März 2018 | Conditional-Typen, Verbesserung von keyof in Kombination mit Intersection-Typen
|
2.9 | 31. Mai 2018 | Unterstützung von number und symbol benannten Eigenschaften mit keyof und endlichen Abbildungen. import(...) -Typen.
|
3.0 | 30. Juli 2018 | Tupel als REST-Parameter, Spread-Ausdrücke für Tupel, generische REST-Parameter, Optionale Elemente in Tupel, unknown als Universaltyp (siehe auch Typentheorie), defaultProps in JSX[33]
|
3.1 | 27. September 2018 | Gemappte Tuple und Array-Typen |
3.2 | 30. November 2018 | Strengere Kontrolle von bind , call und apply
|
3.3 | 31. Januar 2019 | Lockere Regeln für Methoden der Verbindungsarten, inkrementelle Builds für Verbundprojekte |
3.4 | 29. März 2019 | Verbesserungen zu inkrementellen Builds, Composite Projects, Inference, Read-Only Arrays, Type-Checking für globale Variablen und diverse andere |
3.5 | 29. Mai 2019 | Omit als neuer integrierter Typ[34]
|
3.6 | 28. August 2019 | striktere Iterator- und Generatorfunktionen, Unterstützung für Unicode bei Bezeichnern[35] |
3.7 | 5. November 2019 | Optionale Verkettung, Nullish Coalescing Operator, Assertion Functions, verbesserte Unterstützung für Methoden, die never zurückliefern, und viele weitere.[36]
|
3.8 | 20. Februar 2020 | Type-Only Imports und Exports, private Felder, Top-Level await und viele weitere Änderungen.[37]
|
3.9 | 12. Mai 2020 | Geschwindigkeitsverbesserungen beim Build, @ts-expect-error Kommentar, Verbesserungen für Editoren und weitere Änderungen.[38]
|
4.0 | 20. August 2020 | Variadische Tupel, Namen für Elemente in einem Tupel, bessere JSX-Unterstützung[39] |
4.1 | 19. November 2020 | Verkettung von String-Typen[40] |
4.2 | 23. Februar 2021 |
bessere Erhaltung von Typaliasen |
4.3 | 26. Mai 2021 |
Separate Parametertypen in Eigenschaften gettern und settern |
4.4 | 26. August 2021 |
Kontrollflussanalyse von Aliased Bedingungen und Discriminants |
4.5 | 17. November 2021 |
Der „await“-Typ und „promise“-Verbesserungen |
4.6 | 28. Februar 2022 |
Erlaubter Code in Konstruktoren vor |
4.7 | 24. Mai 2022 |
Kontrolle über die Modul-Erkennung |
4.8 | 25. August 2022 |
Verbesserte Schnittpunktreduzierung |
4.9 | 15. November 2022 |
|
5.0 | 16. März 2023 |
Decorators |
5.1 | 1. Juni 2023 |
Vereinfachte Handhabung von |
Weblinks
[Bearbeiten | Quelltext bearbeiten]Einzelnachweise
[Bearbeiten | Quelltext bearbeiten]- ↑ Release 5.5.3. 2. Juli 2024 (abgerufen am 10. Juli 2024).
- ↑ ECMAScript Wiki. Archiviert vom (nicht mehr online verfügbar) am 22. Mai 2008; abgerufen am 3. April 2013 (englisch).
- ↑ a b TypeScript. Abgerufen am 3. April 2013 (englisch, TypeScript Homepage).
- ↑ An introduction to TypeScript’s module system. Archiviert vom (nicht mehr online verfügbar) am 1. Februar 2014; abgerufen am 4. Februar 2014 (englisch, Artikel zum Modulsystem von TypeScript). Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.
- ↑ grunt-ts. Abgerufen am 21. Februar 2014 (englisch).
- ↑ TypeScript Maven Plugin. Abgerufen am 21. Februar 2014 (englisch).
- ↑ TypeScript Gradle Plugin. Abgerufen am 21. Februar 2014 (englisch).
- ↑ IDG News Service staff: Microsoft augments JavaScript for large-scale development. In: InfoWorld. (infoworld.com [abgerufen am 11. Juli 2018]).
- ↑ Announcing TypeScript 1.0. (microsoft.com [abgerufen am 11. Juli 2018]).
- ↑ @COPYRIGHT@: TypeScript: First Impressions - Miguel de Icaza. Abgerufen am 11. Juli 2018 (englisch).
- ↑ Matt Baxter-Reynolds: Microsoft TypeScript: Can the father of C# save us from the tyranny of JavaScript? | ZDNet. In: ZDNet. (zdnet.com [abgerufen am 11. Juli 2018]).
- ↑ Julia Schmidt: TypeScript-Unterstützung für Eclipse. Abgerufen am 11. Juli 2018.
- ↑ TypeScript. In: Eclipse Plugins, Bundles and Products - Eclipse Marketplace. (eclipse.org [abgerufen am 11. Juli 2018]).
- ↑ Sublime Text 4. Abgerufen am 16. August 2022 (englisch).
- ↑ TypeStrong/atom-typescript. Abgerufen am 11. Juli 2018 (englisch).
- ↑ TypeScript. Abgerufen am 11. Juli 2018.
- ↑ Working with TypeScript in Visual Studio 2012. In: Dr. Dobb's. (drdobbs.com [abgerufen am 11. Juli 2018]).
- ↑ New Compiler and Moving to GitHub. (msdn.com [abgerufen am 11. Juli 2018]).
- ↑ TypeScript, Microsoft’s JavaScript for big applications, reaches version 2.0. In: Ars Technica. (arstechnica.com [abgerufen am 11. Juli 2018]).
- ↑ Microsoft Previews New JavaScript-Like Programming Language TypeScript. In: TechCrunch. Abgerufen am 18. Mai 2020 (amerikanisches Englisch).
- ↑ Angular. Abgerufen am 18. Mai 2020.
- ↑ Typed JavaScript at Any Scale. Abgerufen am 18. Mai 2020 (englisch).
- ↑ TypeScript abstract class. In: Qualified.One. 2. Dezember 2022 (englisch).
- ↑ Announcing TypeScript 0.9. 18. Juni 2013, abgerufen am 18. Mai 2020 (amerikanisches Englisch).
- ↑ Handbook - Generics. Abgerufen am 18. Mai 2020 (englisch).
- ↑ Handbook - Unions and Intersection Types. In: www.typescriptlang.org. Abgerufen am 30. November 2020 (englisch).
- ↑ Marius Schulz: Tagged Union Types in TypeScript. 3. November 2016, abgerufen am 4. Januar 2024 (amerikanisches Englisch).
- ↑ Sönke Sothmann: An introduction to TypeScript's module system. blog.oio.de, 31. Januar 2014, archiviert vom am 1. Februar 2014; abgerufen am 21. Februar 2014. Info: Der Archivlink wurde automatisch eingesetzt und noch nicht geprüft. Bitte prüfe Original- und Archivlink gemäß Anleitung und entferne dann diesen Hinweis.
- ↑ Scott Hanselman: What is TypeScript and why with Anders Hejlsberg. Abgerufen am 18. Mai 2020 (englisch).
- ↑ kexugit: TypeScript: JavaScript Development at Application Scale. Abgerufen am 18. Mai 2020 (amerikanisches Englisch).
- ↑ Announcing TypeScript 0.9. 18. Juni 2013, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ https://www.typescriptlang.org/docs/handbook/release-notes/typescript-1-7.html abgerufen am 1. August 2019
- ↑ Announcing TypeScript 3.0. 30. Juli 2018, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ Announcing TypeScript 3.5. 29. Mai 2019, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ Announcing TypeScript 3.6. 28. August 2019, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ Announcing TypeScript 3.7. 5. November 2019, abgerufen am 2. März 2020 (amerikanisches Englisch).
- ↑ Announcing TypeScript 3.8. 20. Februar 2020, abgerufen am 2. März 2020 (amerikanisches Englisch).
- ↑ Announcing TypeScript 3.9. 12. Mai 2020, abgerufen am 14. Mai 2020 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.0. 20. August 2020, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.1. 19. November 2020, abgerufen am 19. Januar 2021 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.2. 23. Februar 2021, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.3. 26. Mai 2021, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.4. 26. August 2021, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.5. 17. November 2021, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.6. 28. Februar 2022, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Announcing TypeScript 4.7. 24. Mai 2022, abgerufen am 31. Mai 2022 (amerikanisches Englisch).
- ↑ Daniel Rosenwasser: Announcing TypeScript 4.8. 25. August 2022, abgerufen am 21. Oktober 2022 (amerikanisches Englisch).
- ↑ Daniel Rosenwasser: Announcing TypeScript 4.9. 15. November 2022, abgerufen am 18. Juni 2023 (amerikanisches Englisch).
- ↑ Daniel Rosenwasser: Announcing TypeScript 5.0. 16. März 2023, abgerufen am 18. Juni 2023 (amerikanisches Englisch).
- ↑ Daniel Rosenwasser: Announcing TypeScript 5.1. 1. Juni 2023, abgerufen am 18. Juni 2023 (amerikanisches Englisch).