TypeScript
#wait
types with JavaScript
#wät
Transpile all the things
TypeScript
#who
- Microsoft (M$) in 2012
- TypeScript == superset of ES3
- JavaScript | TS = JS
- Transpiler
- TypeScript to ES3
- Not only types!
- Classes
- Modules
- Interfaces
- Generics (#wät)
- Angular 2 all in
ES6, ES5, Transpiler
...don't worry - it's all JavaScript
ES6, ES2015, ES2015
it's all the same.
ES6 I
le => arrow
[1, 5, 3, 10, 12].forEach(v => {
if (v % 5 === 0)
fives.push(v);
});
Statement bodies
let numbers = [1, 3, 5, 3, 6, 8];
var added = numbers.map(v => v + 1);
Expression bodies
let a const
function f() {
{
let x;
{
x = "foo";
}
// error, already
//declared in block
let x = "inner";
}
}
Let is the new var (block scope)
Const is #stfu
const a = 'forevernever';
//Boom!
a = 'notsomuch';
ES6 II
Parameters
function f(x, y=12) {
// y is 12 if not passed
return x + y;
}
Default
function f(x, ...y) {
// y is an Array
return x * y.length;
}
Rest (Splat)
Classes (euw)
class Animal extends Creature {
constructor() {
super();
}
eat(camera) {
super.update();
}
get legs() {
return this.bones;
}
set moveing(moving) {
this.moving = moving;
}
}
Prototypes become classes
function f(x, y, z) {
return x + y + z;
}
// Pass each elem of
// array as argument
f(...[1,2,3]) == 6
Spread
ES6 III
Build-ins
class Array {
constructor(...args) { /* ... */ }
static [Symbol.create]() {
}
}
Subclassing
Modules
// lib/math.js
export function sum(x, y) {
return x + y;
}
export var pi = 3.141593;
Export
import * as math from "lib/math";
console.table({
'2π': math.sum(math.pi, math.pi)
});
Import
function timeout(duration = 0) {
return new Promise((resolve, reject) => {
setTimeout(resolve, duration);
})
}
Promises
There is more!
So... fancy...but
...we're on the web
- Old browsers (ES6 table)
- Backwards compatible
- Slow TC39
...so we do ES3 forever?
Transpilation #ftw
...and many more!
> 200
Enter TypeScript I
var height: number = 6;
var name: string = "bob";
var isDone: boolean = false;
var list:number[] = [1, 2, 3];
var list:Array<number> = [1, 2, 3];
enum Color {Red, Green, Blue};
var notSure: any = 4;
function warnUser(): void {
alert("This is my warning message");
}
Types
interface LabelledValue {
label: string;
}
function printLabel(labelledObj: LabelledValue) {
console.log(labelledObj.label);
}
Interfaces
interface SquareConfig {
color?: string;
width?: number;
}
Optionals
interface SearchFunc {
(
source: string,
subString: string
): boolean;
}
Function Types
Enter TypeScript II
var name = "Bob", time = "today";
`Hello ${name}, how are you ${time}?`
Single line (interpolated)
`In JavaScript
this is
not legal.`
Multi line #wow
class Flies {
fly() {
alert('Flies!');
}
}
class Climbs {
climb() {
alert('Climbs!');
}
}
class Bulletproof {
deflect() {
alert('Cant kill it');
}
}
class BeetleGuy implements Climbs, Bulletproof {
climb: () => void;
deflect: () => void;
}
//This is no magic :(
applyMixins (BeetleGuy, [Climbs, Bulletproof]);
Mixins
Enter TypeScript III
module Validation {
export interface StringValidator {
isAcceptable(s: string): boolean;
}
var lettersRegexp = /^[A-Za-z]+$/;
var numberRegexp = /^[0-9]+$/;
export class LettersOnlyValidator implements StringValidator {
isAcceptable(s: string) {
return lettersRegexp.test(s);
}
}
export class ZipCodeValidator implements StringValidator {
isAcceptable(s: string) {
return s.length === 5 && numberRegexp.test(s);
}
}
}
import validation = require('./Validation');
Modules
TypeScript #destiny
- ES6/ES7 compatible transpiler
- Generators
- For..of
- Symbols
- Additional type system
- Maintainable app development
- Don't break at runtime but at compiler check
- External libraries give type definitions
- Annotation support (Angular 2)
- Target different ES* versions
Transpile all the things (TypeScript)
By Tobias Deekens
Transpile all the things (TypeScript)
- 1,104