Aller au contenu

TypeScript

Un article de Wikipédia, l'encyclopédie libre.

TypeScript
Logo.

Date de première version (12 ans, 205 jours)
Paradigme Multi-paradigme
Auteur Anders Hejlsberg...
Dernière version 5.5.4 ()[1]Voir et modifier les données sur Wikidata
Version en développement 4.6 RC ()[2]Voir et modifier les données sur Wikidata
Typage dynamique,faible,fort optionnel,statique optionnel
Influencé par JavaScript
C#
Java
CoffeeScriptVoir et modifier les données sur Wikidata
Écrit en JavaScriptet TypeScriptVoir et modifier les données sur Wikidata
Licence Open Web Foundation,compilateur:Apache 2.0
Site web typescriptlang.orgVoir et modifier les données sur Wikidata
Extension de fichier ts et tsxVoir et modifier les données sur Wikidata

TypeScriptest unlangage de programmationlibreetopen sourcedéveloppé parMicrosoftqui a pour but d'améliorer et de sécuriser la production de codeJavaScript.Il s'agit d'un sur-ensemble syntaxique strict de JavaScript (c'est-à-dire que tout code JavaScript correct peut être utilisé avec TypeScript). Le code TypeScript esttranscompiléen JavaScript et peut ainsi être interprété par n'importe quelnavigateur weboumoteur JavaScript.TypeScript a été cocréé parAnders Hejlsberg,principal inventeur deC#[3],[4],[5],[6].

TypeScript permet untypagestatique optionnel des variables et des fonctions, la création de classes et d'interfaces, l'import de modules, tout en conservant l'approche non-contraignante de JavaScript. Il supporte la spécificationECMAScript6.

TypeScript prend en charge les fichiers de définition qui peuvent contenir des informations sur le type des bibliothèques JavaScript existantes, tout comme les fichiers d'en-têteC++peuvent décrire la structure des fichiers objets[7]existants. Cela permet à d'autres programmes d'utiliser les valeurs définies dans les fichiers comme s'il s'agissait d'entités TypeScript de type statique. Il existe des fichiers d'en-tête tiers pour les bibliothèques populaires telles quejQueryetD3.js.Des en-têtes TypeScript pour les modules de baseNode.jssont également disponibles, permettant le développement de programmes Node.js dans TypeScript.

LecompilateurTypeScript est lui-même écrit en TypeScript et compilé en JavaScript. Il est sous licenceApache License2.0. TypeScript est inclus en tant que langage de programmation de première classe dansMicrosoft Visual Studio2013 Update 2 et versions ultérieures, à côté deC#et d'autres langagesMicrosoft.Une extension officielle permet également à Visual Studio 2012 de prendre en charge TypeScript.Anders Hejlsberg,architecte principal deC#et créateur deDelphietTurbo Pascal,a travaillé sur le développement de TypeScript.

TypeScript a été rendu public en(à la version 0.8), après deux ans de développement interne chez Microsoft[8],[9].Peu de temps après l'annonce,Miguel de Icazaa salué le langage lui-même, mais a critiqué le manque d'environnement de développementmature en dehors deMicrosoft Visual Studio,qui n’était pas disponible surLinuxetOS X[10],[11].

L'environnement de développementVisual Studio Code,porté par le frameworkElectron(à l'initiative deGoogleChromium), disponible sous Windows, MacOSX et Linux, permet désormais de combler ce vide.

Aujourd'hui, il existe un support dans d'autres IDE, en particulier dansEclipse,via un plug-in fourni parPalantir Technologies.Diverséditeurs de texte,y comprisEmacs,Vim,Webstorm, Atom et le propreVisual Studio Codede Microsoft prennent également en charge TypeScript.

TypeScript 0.9, publié en 2013, a ajouté la prise en charge des génériques. TypeScript 1.0 a été publié lors de la conférence des développeurs Microsoft Build en 2014.Visual Studio 2013Update 2 fournit une prise en charge intégrée de TypeScript.

En,l'équipe de développement a annoncé un nouveau compilateur TypeScript, revendiquant 5 fois plus de performances. Simultanément, le code source, qui était initialement hébergé surCodePlex,a été déplacé versGitHub.

Le,TypeScript 2.0 est sorti; il a introduit plusieurs fonctionnalités, notamment la possibilité pour les programmeurs d'empêcher éventuellement l'attribution de valeurs "null" aux variables, parfois appeléel'erreur d'un milliard de dollars.

TypeScript 3.0 a été publié le,apportant de nombreux ajouts de langage comme les tuples dans les paramètres de repos et les expressions réparties, les paramètres de repos avec les types de tuple, les paramètres de repos génériques, etc.

La version 4.0 de TypeScript a été publiée le 10 février 2021. Cette version n'apporte pas de changement majeur au langage[12].

TypeScript a été conçu pour pallier les lacunes de JavaScript pour le développement d'applications à grande échelle à la fois chez Microsoft et chez leurs clients externes. Les défis liés à la gestion de code JavaScript complexe ont conduit à une demande d'outils personnalisés pour faciliter le développement de composants dans le langage.

Les développeurs de TypeScript ont cherché une solution qui ne romprait pas la compatibilité avec la norme et sa prise en charge multiplateforme. Sachant que la proposition de normeECMAScriptactuelle promettait une prise en charge future de la programmation basée sur les classes, TypeScript était basé sur cette proposition. Cela a conduit à un compilateur JavaScript avec un ensemble d'extensions de langage syntaxique, un sur-ensemble basé sur la proposition, qui transforme les extensions en JavaScript standard. En ce sens, TypeScript était un aperçu de ce à quoi s'attendre d'ECMAScript 2015. Un aspect unique qui n'est pas dans la proposition, mais ajouté à TypeScript, est letypage statiquefacultatif qui permet uneanalyse statiquedu langage, ce qui facilite l'outillage et la prise en charge IDE.

Fonctionnalités

[modifier|modifier le code]

Le langage ajoute les fonctionnalités suivantes àECMAScript6:

Depuis la version 1.6, la syntaxeJSXest supportée.

Typage statique

[modifier|modifier le code]

Le langage permet de préciser le contenu d'une variable ou la valeur de retour d'une fonction (ou d'une méthode):

// Création d'une variable contenant une valeur booléenne.
varmaValeurBooleenne:boolean=false;

// Création d'une variable contenant une chaîne de caractères.
varmaChaineDeCaractere:string="Hello World";

// Création d'une variable contenant un nombre.
varmonNombre:number=1;

// Création d'une fonction retournant une chaîne de caractères.
functionmaFonction():string{
return"Ma valeur de retour";
}

Type générique

[modifier|modifier le code]

Il est également possible de créer des types génériques. Pour une méthode:

functionmaFonction<T>(parametre:T){
// Contenu de la fonction.
}

Pour une classe:

classMaClasse<T>{
maVariable:T;
// Contenu de la classe.
}

// Création d'une instance de la classe "MaClasse" en définissant un type.
varmonInstance=newMaClasse<string>();
monInstance.maVariable="Hello World";

Les interfaces sont un concept essentiel et permettent d'avoir cette notion de typage. En créant une interface, il devient alors possible de l'utiliser pour préciser le contenu d'une variable ou d'une classe:

interfaceMonInterface{
// Création d'une signature de variable.
maVariable:string;
// Création d'une signature de méthode.
maMethode(parametre:string):void;
}

classMaClasseimplementsMonInterface{
maVariable:string;
maMethode(parametre:string):void{
// Contenu de la méthode.
}
}

// Précision du type de la variable en utilisant l'interface.
varinstance:MonInterface=newMaClasse();

DefinitelyTyped

[modifier|modifier le code]

Une large bibliothèque d'interface, destinée à des classes (ou fonctions) qui ont été développés en JavaScript, est disponible sur un dépôt GitHub par borisyankov.

Le langage apporte le support des classes. L'héritage y est également pris en charge:

classMaClasseDeBase{
private_firstname;
private_lastname;

publicconstructor(firstname:string,lastname:string){
this._firstname=firstname;
this._lastname=lastname;
}

publicdireBonjour():string{
return"Bonjour"+this._firstname+","+this._lastname;
}
}

// La classe hérite de "MaClasseDeBase".
classMaClasseextendsMaClasseDeBase{
publicconstructor(firstname:string,lastname:string){
// Accède au constructeur de "MaClasseDeBase".
super(firstname,lastname);
}
}

// Création d'une instance de "MaClasse" et
// appel de la méthode: "direBonjour" de la classe parente: "MaClasseDeBase".
varmonInstance:MaClasse=newMaClasse("Jean","Dupond");
monInstance.direBonjour();

Comme il est montré dans l'exemple ci-dessus, le langage autorise les trois types de visibilités, à c'est-à-dire:public,privateetprotected.Ce dernier est arrivé avec la version 1.3[13].

La création de module (que l'on peut qualifier d'espace de nommage) est permise en utilisant le mot-clémodule:

modulemon.espace.de.nom{
// Contenu du module: classe, fonction, etc.
}

TypeScript distingue les modules internes des modules externes. Les modules internes sont basées sur la syntaxe de ECMAScript 6, tandis que les modules externes exploitent une bibliothèque externe:AMDouCommonJS[14].

Énumérations

[modifier|modifier le code]

L'utilisation d'énumération dans du code TypeScript est offerte à travers le mot-cléenum.

Sans la définition de valeur à une constante:

enumCouleur{Bleu,Rouge,Vert};

Il est à noter que, par défaut, la première constante de l'énumération aura pour valeur, 0.

Avec la définition de valeur:

enumCouleur{Bleu=0,Rouge=1,Vert=2};

Il est tout à fait possible de donner la valeur "1"(ou tout autre nombre) à la première constante.

Paramètres optionnels

[modifier|modifier le code]

Un paramètre peut être défini comme optionnel en TypeScript, en ajoutant le caractère?après le nom de la variable:

functionmaFonction(monParametre?:string){
// On teste si le paramètre "monParametre" a une valeur.
if(monParametre){
returnmonParametre;
}else{
// Dans le cas contraire, une valeur par défaut est retournée.
return"Hello World";
}
}

// La valeur retournée sera: "Hello World" sans avoir un message d'avertissement lors de la compilation.
varresultat:string=maFonction();
// La valeur retournée sera: "Ma valeur".
varresultat:string=maFonction("Ma valeur");

Les unions sont arrivées avec la version 1.4 du langage[15].Cette fonctionnalité autorise l'ajout de multiples types pour le paramètre d'une fonction (ou d'une méthode):

// La fonction autorise que le paramètre soit une chaîne de caractère ou un tableau de chaîne de caractère.
functionmaFonction(monParametre:string|string[]):void{
if(typeofmonParametre==="string"){
// Traitement de ma chaîne de caractère.
}else{
// Traitement de mon tableau.
}
}

En plus des unions, la version 1.4 apporte la possibilité de créer des alias:

// Création d'un alias basé sur le type "number".
typeMonAlias=number;
// Utilisation de l'alias ci-dessus.
varmonNombre:MonAlias=1;

Outils de développement

[modifier|modifier le code]

Pour effectuer la transformation de code TypeScript en code JavaScript, un compilateur est nécessaire. Pour cela, il faut utiliser le compilateur, nommétsc.Il peut être installé depuis le gestionnaire de packagenpm.La version actuelle supporte, par défaut, la spécification ECMAScript 3. Il supporte également des fonctionnalités exclusives de la spécification ECMAScript 5 et 6 (en spécifiant dans les options du compilateur)[16].

Environnements de développement

[modifier|modifier le code]

Le compilateur peut être associé à divers environnements tel que:

Liens externes

[modifier|modifier le code]
  1. aetb«Release 5.5.4»,(consulté le)
  2. «https://github /microsoft/TypeScript/releases/tag/v4.6-rc»
  3. (en)«Microsoft takes the wraps off TypeScript, a superset of JavaScript», surZDNet(consulté le).
  4. (en)«TypeScript: JavaScript Development at Application Scale»,surSomasegar's blog,Microsoft Developer Network(version dusurInternet Archive).
  5. (en)«Microsoft TypeScript: Can the father of C# save us from the tyranny of JavaScript?», surZDNet(consulté le).
  6. Microsoft Augments Javascript for Large-scale DevelopmentCIO.
  7. Un fichier objet est un fichier contenant du code objet, c'est-à-dire un code machine au format déplaçable qui n'est généralement pas directement exécutable. Il existe différents formats pour les fichiers objets et le même code objet peut être conditionné dans différents fichiers objets. Un fichier objet peut également fonctionner comme une bibliothèque partagée.
  8. (en)Microsoft augments JavaScript for large-scale development
  9. (en)Announcing TypeScript 1.0
  10. (en)TypeScript: First Impressions
  11. (en)Microsoft TypeScript: Can the father of C# save us from the tyranny of JavaScript?
  12. (en)Wesley Wigham, «Release TypeScript 4.0.7»Accès libre,surgithub,(consulté le).
  13. Announcing TypeScript 1.3
  14. An introduction to TypeScript’s module system
  15. Announcing TypeScript 1.4
  16. (en)«tsc CLI options», surtypescriptlang.org,(consulté le).
  17. Using TypeScript in Visual Studio Code - MSDN Blogs
  18. TypeScript Support in WebStorm
  19. Sublime Text, Vi, Emacs: TypeScript enabled!
  20. Supported Syntax Highlighting and Themes: Support - Codeanywhere
  21. «IntelliJ IDEA 2016.2 Help:: TypeScript Support», surjetbrains(consulté le).