Paradigm | Multi-paradigm: functional, generic, imperative, object-oriented |
---|---|
Designed by | Microsoft |
Developer | Microsoft |
First appeared | 1 October 2012 [1] |
Stable release | |
Typing discipline | Duck, gradual, structural [3] |
License | Apache License 2.0 |
Filename extensions | .ts, .tsx, .mts, .cts |
Website | www |
Influenced by | |
C#, F#, [4] Java, JavaScript, ActionScript [5] | |
Influenced | |
AtScript, AssemblyScript, ArkTS |
TypeScript (abbreviated as TS) is a free and open-source high-level programming language developed by Microsoft that adds static typing with optional type annotations to JavaScript. It is designed for the development of large applications and transpiles to JavaScript. [6]
TypeScript may be used to develop JavaScript applications for both client-side and server-side execution (as with Node.js, Deno or Bun). Multiple options are available for transpilation. The default TypeScript Compiler can be used, [7] or the Babel compiler can be invoked to convert TypeScript to JavaScript.
TypeScript supports definition files that can contain type information of existing JavaScript libraries, much like C++ header files can describe the structure of existing object files. This enables other programs to use the values defined in the files as if they were statically typed TypeScript entities. There are third-party header files for popular libraries such as jQuery, MongoDB, and D3.js. TypeScript headers for the Node.js library modules are also available, allowing development of Node.js programs within TypeScript. [8]
The TypeScript compiler is itself written in TypeScript and compiled to JavaScript. It is licensed under the Apache License 2.0. Anders Hejlsberg, lead architect of C# and creator of Delphi and Turbo Pascal, has worked on the development of TypeScript. [9] [10] [11] [12]
TypeScript was released to the public in October 2012, with version 0.8, after two years of internal development at Microsoft. [13] [14] Soon after the initial public release, Miguel de Icaza praised the language itself, but criticized the lack of mature IDE support apart from Microsoft Visual Studio, which was not available on Linux and macOS at the time. [15] [16] As of April 2021 there is support in other IDEs and text editors, including Emacs, Vim, WebStorm, Atom [17] and Microsoft's own Visual Studio Code. [18] TypeScript 0.9, released in 2013, added support for generics. [19]
TypeScript 1.0 was released at Microsoft's Build developer conference in 2014. [20] Visual Studio 2013 Update 2 provided built-in support for TypeScript. [21] Further improvement were made in July 2014, when the development team announced a new TypeScript compiler, asserted to have a five-fold performance increase. Simultaneously, the source code, which was initially hosted on CodePlex, was moved to GitHub. [22]
On 22 September 2016, TypeScript 2.0 was released, introducing several features, including the ability for programmers to optionally enforce null safety, [23] to mitigate what's sometimes referred to as the billion-dollar mistake.
TypeScript 3.0 was released on 30 July 2018, [24] bringing many language additions like tuples in rest parameters and spread expressions, rest parameters with tuple types, generic rest parameters and so on. [25]
TypeScript 4.0 was released on 20 August 2020. [26] While 4.0 did not introduce any breaking changes, it added language features such as Custom JSX Factories and Variadic Tuple Types. [26]
TypeScript 5.0 was released on 16 March 2023 and included support for decorators. [27]
TypeScript originated from the shortcomings of JavaScript for the development of large-scale applications both at Microsoft and among their external customers. [28] Challenges with dealing with complex JavaScript code led to demand for custom tooling to ease developing of components in the language. [29]
Developers sought a solution that would not break compatibility with the ECMAScript standard and its ecosystem, so a compiler was developed to transform a superset of JavaScript with type annotations and classes (TypeScript files) back into vanilla ECMAScript 5 code. TypeScript classes were based on the then-proposed ECMAScript 6 class specification to make writing prototypal inheritance less verbose and error-prone, and type annotations enabled IntelliSense and improved tooling.
TypeScript adds the following syntax extensions to JavaScript:
Syntactically, TypeScript is very similar to JScript .NET, another Microsoft implementation of the ECMA-262 language standard that added support for static typing and classical object-oriented language features such as classes, inheritance, interfaces, and namespaces. Other inspirations include Java and C#.
TypeScript provides static typing through type annotations to enable type checking at compile time.
functionadd(left:number,right:number):number{returnleft+right;}
Primitive types are annotated using all-lowercase types, such as number
, boolean
, bigint
, and string
. These types are distinct from their boxed counterparts (Number
, Boolean
, etc), which cannot have operations performed from values directly (a Number
and number
cannot be added). There are additionally undefined
and null
types for their respective values.
All other non-primitive types are annotated using their class name, such as Error
. Arrays can be written in two different ways which are both syntactically the same: the generic-based syntax Array<T>
and a shorthand with T[]
.
Additional built-in data types are tuples, unions, never
and any
:
[type1, type2, ..., typeN]
.|
symbol (string | number
).never
type is used when a given type should be impossible to create, which is useful for filtering mapped types.any
supports the same operations as a value in JavaScript and minimal static type checking is performed, [31] which makes it suitable for weakly or dynamically-typed structures. This is generally discouraged practice and should be avoided when possible. [32] Type annotations can be exported to a separate declarations file to make type information available for TypeScript scripts using types already compiled into JavaScript. Annotations can be declared for an existing JavaScript library, as has been done for Node.js and jQuery.
The TypeScript compiler makes use of type inference when types are not given. For example, the add
method in the code above would be inferred as returning a number
even if no return type annotation had been provided. This is based on the static types of left
and right
being number
s, and the compiler's knowledge that the result of adding two number
s is always a number
.
If no type can be inferred because of lack of declarations (such as in a JavaScript module without types), then it defaults to the dynamic any
type. Additional module types can be provided using a .d.ts declaration file using the declare module "moduleName"
syntax.
When a TypeScript script gets compiled, there is an option to generate a declaration file (with the extension .d.ts
) that functions as an interface to the components in the compiled JavaScript. In the process, the compiler strips away all function and method bodies and preserves only the signatures of the types that are exported. The resulting declaration file can then be used to describe the exported virtual TypeScript types of a JavaScript library or module when a third-party developer consumes it from TypeScript.
The concept of declaration files is analogous to the concept of header files found in C/C++.
declarenamespaceArithmetics{add(left:number,right:number):number;subtract(left:number,right:number):number;multiply(left:number,right:number):number;divide(left:number,right:number):number;}
Type declaration files can be written by hand for existing JavaScript libraries, as has been done for jQuery and Node.js.
Large collections of declaration files for popular JavaScript libraries are hosted on GitHub in DefinitelyTyped.
TypeScript supports generic programming using a syntax similar to Java. [33] The following is an example of the identity function. [34]
functionid<T>(x:T):T{returnx;}
TypeScript uses the same annotation style for class methods and fields as for functions and variables respectively. Compared with vanilla JavaScript classes, a TypeScript class can also implement an interface through the implements
keyword, use generic parameters similarly to Java, and specify public and private fields.
classPerson{publicname:string;privateage:number;privatesalary: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})`;}}
Union types are supported in TypeScript. [35] The values are implicitly "tagged" with a type by the language, and may be retrieved using a typeof
call for primitive values and an instanceof
comparison for complex data types. Types with overlapping usage (e.g. a slice method exists on both strings and arrays, the plus operator works on both strings and numbers) don't need additional narrowing to use these features.
functionsuccessor(n:number|bigint):number|bigint{// types that support the same operations don't need narrowingreturn++n;}functiondependsOnParameter(v:string|Array<string>|number){// distinct types need narrowingif(vinstanceofArray){// do something}elseif(typeof(v)==="string"){// do something else}else{// has to be a number}}
TypeScript adds an 'enum' data type to JavaScript.
enumCardsuit{Clubs,Diamonds,Hearts,Spades};varc:Cardsuit=Cardsuit.Diamonds;
By default, enums number members starting at 0; this can be overridden by setting the value of the first:
enumCardsuit{Clubs=1,Diamonds,Hearts,Spades};varc:Cardsuit=Cardsuit.Diamonds;
All the values can be set:
enumCardsuit{Clubs=1,Diamonds=2,Hearts=4,Spades=8};varc:Cardsuit=Cardsuit.Diamonds;
TypeScript supports mapping the numeric value to its name. For example, this finds the name of the value 2:
enumCardsuit{Clubs=1,Diamonds,Hearts,Spades};varsuitName:string=Cardsuit[2];alert(suitName);
TypeScript distinguishes between modules and namespaces. Both features in TypeScript support encapsulation of classes, interfaces, functions and variables into containers. Namespaces (formerly internal modules) use JavaScript immediately-invoked function expressions to encapsulate code, whereas modules (formerly external modules) use existing JavaScript library patterns (CommonJS or ES Modules). [36]
As TypeScript is simply a superset of JavaScript, existing JavaScript can be quickly adapted to TypeScript and TypeScript program can seamlessly consume JavaScript. The compiler can target all ECMAScript versions 5 and above, transpiling modern features like classes and arrow functions to their older counterparts.
With TypeScript, it is possible to use existing JavaScript code, incorporate popular JavaScript libraries, and call TypeScript-generated code from other JavaScript. [37] Type declarations for these libraries are usually provided with the source code but can be declared or installed separately if needed.
The TypeScript compiler, named tsc
, is written in TypeScript. As a result, it can be compiled into regular JavaScript and can then be executed in any JavaScript engine (e.g. a browser). The compiler package comes bundled with a script host that can execute the compiler. It is also available as a Node.js package that uses Node.js as a host.
The compiler can "target" a particular edition of ECMAScript (such as ES5 for legacy browser compatibility), but by default compiles for the latest standards.
Using plug-ins, TypeScript can be integrated with build automation tools, including Grunt (grunt-ts [43] ), Apache Maven (TypeScript Maven Plugin [44] ), Gulp (gulp-typescript [45] ) and Gradle (TypeScript Gradle Plugin [46] ).
TSLint [47] scans TypeScript code for conformance to a set of standards and guidelines. ESLint, a standard JavaScript linter, also provided some support for TypeScript via community plugins. However, ESLint's inability to leverage TypeScript's language services precluded certain forms of semantic linting and program-wide analysis. [48] In early 2019, the TSLint team announced the linter's deprecation in favor of typescript-eslint
, a joint effort of the TSLint, ESLint and TypeScript teams to consolidate linting under the ESLint umbrella for improved performance, community unity and developer accessibility. [49]
CodeDOM [50] provides types that represent common types of source code elements, which will be transformed to data types, classes and statements etc. of a programming language through a CodeDOMProvider. [51] Programmers use CodeDOM and a CodeDOM provider to construct a code generator that generates codes for an application domain. TypeScript CodeDOM Provider [52] generates TypeScript codes according to a CodeDOM.
Version number | Release date | Significant changes |
---|---|---|
0.8 | 1 October 2012 | |
0.9 | 18 June 2013 | |
1.0 | 12 April 2014 | |
1.1 | 6 October 2014 | performance improvements |
1.3 | 12 November 2014 | protected modifier, tuple types |
1.4 | 20 January 2015 | union types, let and const declarations, template strings, type guards, type aliases |
1.5 | 20 July 2015 | ES6 modules, namespace keyword, for..of support, decorators |
1.6 | 16 September 2015 | JSX support, intersection types, local type declarations, abstract classes and methods, user-defined type guard functions |
1.7 | 30 November 2015 | async and await support, |
1.8 | 22 February 2016 | constraints generics, control flow analysis errors, string literal types, allowJs |
2.0 | 22 September 2016 | null- and undefined-aware types, control flow based type analysis, discriminated union types, never type, readonly keyword, type of this for functions |
2.1 | 8 November 2016 | keyof and lookup types, mapped types, object spread and rest, |
2.2 | 22 February 2017 | mix-in classes, object type, |
2.3 | 27 April 2017 | async iteration, generic parameter defaults, strict option |
2.4 | 27 June 2017 | dynamic import expressions, string enums, improved inference for generics, strict contravariance for callback parameters |
2.5 | 31 August 2017 | optional catch clause variables |
2.6 | 31 October 2017 | strict function types |
2.7 | 31 January 2018 | constant-named properties, fixed-length tuples |
2.8 | 27 March 2018 | conditional types, improved keyof with intersection types |
2.9 | 14 May 2018 | support for symbols and numeric literals in keyof and mapped object types |
3.0 | 30 July 2018 | project references, extracting and spreading parameter lists with tuples |
3.1 | 27 September 2018 | mappable tuple and array types |
3.2 | 30 November 2018 | stricter checking for bind , call , and apply |
3.3 | 31 January 2019 | relaxed rules on methods of union types, incremental builds for composite projects |
3.4 | 29 March 2019 | faster incremental builds, type inference from generic functions, readonly modifier for arrays, const assertions, type-checking global this |
3.5 | 29 May 2019 | faster incremental builds, omit helper type, improved excess property checks in union types, smarter union type checking |
3.6 | 28 August 2019 | Stricter generators, more accurate array spread, better Unicode support for identifiers |
3.7 | 5 November 2019 | Optional chaining, nullish coalescing |
3.8 | 20 February 2020 | Type-only imports and exports, ECMAScript private fields, top-level await |
3.9 | 12 May 2020 | Improvements in inference, speed improvements |
4.0 | 20 August 2020 | Variadic tuple types, labeled tuple elements |
4.1 | 19 November 2020 | Template literal types, key remapping in mapped types, recursive conditional types |
4.2 | 25 February 2021 | Smarter type alias preservation, leading/middle rest elements in tuple types, stricter checks for the in operator, abstract construct signatures |
4.3 | 26 May 2021 | Separate write types on properties, override and the --noImplicitOverride flag, template string type improvements |
4.4 | 26 August 2021 | Control flow analysis of aliased conditions and discriminants, symbol and template string pattern index signatures |
4.5 | 17 November 2021 | Type and promise improvements, supporting lib from node_modules , template string types as discriminants, and es2022 module |
4.6 | 28 February 2022 | Type inference and checks improvements, support for ES2022 target, better ECMAScript handling |
4.7 | 24 May 2022 | Support for ES modules, instantiation expressions, variance annotations for type parameters, better control-flow checks and type check improvements |
4.8 | 25 August 2022 | Intersection and union types improvements, better type inference |
4.9 | 15 November 2022 | satisfies operator, auto-accessors in classes (proposal), improvements in type narrowing and checks |
5.0 | 16 March 2023 | ES decorators (proposal), type inference improvements, bundler module resolution mode, speed and size optimizations |
5.1 | 1 June 2023 | Easier implicit returns for undefined and unrelated types for getters and setters |
5.2 | 24 August 2023 | using declarations and explicit resource management, decorator metadata and named and anonymous tuple elements |
5.3 | 20 November 2023 | Improved type narrowing, correctness checks and performance optimizations |
5.4 | 6 March 2024 | Object.groupBy and Map.groupBy support |
5.5 | 20 June 2024 | Inferred Type Predicates, Regular Expression Syntax Checking, and Type Imports in JSDoc |
5.6 | 9 September 2024 | Advanced type inference, variadic tuple enhancements, partial module declarations. |
5.7 | 22 November 2024 |
KDevelop is a free and open-source integrated development environment (IDE) for Unix-like computer operating systems and Windows. It provides editing, navigation and debugging features for several programming languages, and integration with build automation and version-control systems, using a plugin-based architecture.
D, also known as dlang, is a multi-paradigm system programming language created by Walter Bright at Digital Mars and released in 2001. Andrei Alexandrescu joined the design and development effort in 2007. Though it originated as a re-engineering of C++, D is now a very different language. As it has developed, it has drawn inspiration from other high-level programming languages. Notably, it has been influenced by Java, Python, Ruby, C#, and Eiffel.
JScript is Microsoft's legacy dialect of the ECMAScript standard that is used in Microsoft's Internet Explorer web browser and HTML Applications, and as a standalone Windows scripting language.
Google Web Toolkit, or GWT Web Toolkit, is an open-source set of tools that allows web developers to create and maintain JavaScript front-end applications in Java. It is licensed under Apache License 2.0.
Aptana, Inc. is a company that makes web application development tools for use with a variety of programming languages. Aptana's main products include Aptana Studio, Aptana Cloud and Aptana Jaxer.
The following tables list notable software packages that are nominal IDEs; standalone tools such as source-code editors and GUI builders are not included. These IDEs are listed in alphabetic order of the supported language.
JSDoc is a markup language used to annotate JavaScript source code files. Using comments containing JSDoc, programmers can add documentation describing the application programming interface of the code they're creating. This is then processed, by various tools, to produce documentation in accessible formats like HTML and Rich Text Format. The JSDoc specification is released under CC BY-SA 3.0, while its companion documentation generator and parser library is free software under the Apache License 2.0.
CodeLite is a free and open-source IDE for the C, C++, PHP, and JavaScript (Node.js) programming languages.
JSLint is a static code analysis tool used in software development for checking if JavaScript source code complies with coding rules. It is provided primarily as a browser-based web application accessible through the domain jslint.com, but there are also command-line adaptations. It was created in 2002 by Douglas Crockford.
Node.js is a cross-platform, open-source JavaScript runtime environment that can run on Windows, Linux, Unix, macOS, and more. Node.js runs on the V8 JavaScript engine, and executes JavaScript code outside a web browser.
CoffeeScript is a programming language that compiles to JavaScript. It adds syntactic sugar inspired by Ruby, Python, and Haskell in an effort to enhance JavaScript's brevity and readability. Specific additional features include list comprehension and destructuring assignment.
Dart is a programming language designed by Lars Bak and Kasper Lund and developed by Google. It can be used to develop web and mobile apps as well as server and desktop applications.
Elm is a domain-specific programming language for declaratively creating web browser-based graphical user interfaces. Elm is purely functional, and is developed with emphasis on usability, performance, and robustness. It advertises "no runtime exceptions in practice", made possible by the Elm compiler's static type checking.
asm.js is a subset of JavaScript designed to allow computer software written in languages such as C to be run as web applications while maintaining performance characteristics considerably better than standard JavaScript, which is the typical language used for such applications.
The Windows Library for JavaScript is an open-source JavaScript library developed by Microsoft. It has been designed with the primary goal of easing development of Windows Store apps for Windows 8 and Windows 10, as well as Windows Phone apps for Windows Phone 8.1, Windows 10 Mobile and Xbox One applications using HTML5 and JavaScript, as an alternative to using WinRT XAML and C#, VB.NET or C++ (CX).
ESLint is a static code analysis tool for identifying problematic patterns found in JavaScript code. It was created by Nicholas C. Zakas in 2013. Rules in ESLint are configurable, and customized rules can be defined and loaded. ESLint covers both code quality and coding style issues. ESLint supports current standards of ECMAScript, and experimental syntax from drafts for future standards. Code using JSX or TypeScript can also be processed when a plugin or transpiler is used.
Babel is a free and open-source JavaScript transcompiler that is mainly used to convert ECMAScript 2015+ (ES6+) code into backwards-compatible JavaScript code that can be run by older JavaScript engines. It allows web developers to take advantage of the newest features of the language.
PureScript is a strongly-typed, purely-functional programming language that transpiles to JavaScript, C++11, Erlang, and Go. It can be used to develop web applications, server side apps, and also desktop applications with use of Electron or via C++11 and Go compilers with suitable libraries. Its syntax is mostly comparable to that of Haskell. In addition, it introduces row polymorphism and extensible records. Also, contrary to Haskell, the PureScript language is defined as having a strict evaluation strategy, although there are non-conforming back-ends which implement a lazy evaluation strategy.
Deno is a runtime for JavaScript, TypeScript, and WebAssembly that is based on the V8 JavaScript engine and the Rust programming language. Deno was co-created by Ryan Dahl, who also created Node.js.
TypeScript was directly influenced by F#: one of the originators of TypeScript was Luke Hoban, who began TypeScript (then called Strada) immediately after working on F# 2.0. Recently he noted the influence of F# on early parts of the TypeScript design [Hoban 2017].
But TypeScript only delivers half of the value in using a strongly typed language to Unix developers: strong typing. Intellisense, code completion and refactoring are tools that are only available to Visual Studio Professional users on Windows. There is no Eclipse, MonoDevelop or Emacs support for any of the language features
And I think this is a pretty big misstep. If you're building web apps that run on anything other than Windows, you're likely using a Mac and most likely not using Visual Studio. You need the Visual Studio plug-in to get the IntelliSense. All you get without Visual Studio is the strong-typing. You don't get the productivity benefits you get from IntelliSense..