Tomasz Ducin
JavaScript + Java
= TypeScript
Tomasz Ducin
22nd April 2017, Warsaw
JavaScript + Java
= TypeScript
Tomasz Ducin
14th February 2017, Warsaw
data:image/s3,"s3://crabby-images/b1fe1/b1fe181e2eca83567b786a23175c40e7cafd98a0" alt=""
#11
JavaScript + Java
= TypeScript
Tomasz Ducin
8th February 2017, Warsaw
data:image/s3,"s3://crabby-images/02845/028455f31166f5ad701bb5bdb622115df174af45" alt=""
JavaScript + C#
= TypeScript
Tomasz Ducin
31st January 2017, Warsaw
data:image/s3,"s3://crabby-images/763fe/763fe1f2e04107e349deef8453976111c4b4dd6a" alt=""
#196
JavaScript + Java
= TypeScript
Tomasz Ducin
30th September 2016, Warsaw
JavaScript + Java
= TypeScript
Tomasz Ducin
23rd September 2016, Praha
JavaScript + Java
= TypeScript
Tomasz Ducin
8th September 2016, Warsaw
You don't know TS
Tomasz Ducin
15th June 2016, Darmstadt
JavaScript + Java
= TypeScript
JavaScript + Java = TypeScript
Tomasz Ducin
8th June 2016, Warsaw
#22
Tomasz Ducin
23rd April 2016, Szczecin
JavaScript + Java
= TypeScript
Tomasz Ducin
11th April 2016, Warsaw
JavaScript + Java
= TypeScript
Tomasz Ducin
JavaScript, Java, Python
software developer @ Ivanti
trainer @ Bottega IT Solutions
blah, blah, blah...
data:image/s3,"s3://crabby-images/0277a/0277aa02cfe72fe2640503d17716004a97524e41" alt=""
data:image/s3,"s3://crabby-images/3ad2c/3ad2c690ba01f8c36ba56f6b47417a7471d9765a" alt=""
data:image/s3,"s3://crabby-images/027cf/027cf5a093fc0593e6c2e20f40fd468dde130d8b" alt=""
Agenda
- a glance at TS
- JS tooling landscape
- TypeScript - and tech problems:
solved & unsolved - JS, ES6, TS, CS... & flow
- TS: profit and loss
TypeScript
experienced?
Are you
- private customer banking interface
- TypeScript-based
- 1+ year to go on production
- deployed on 120+ Scandinavian banks
Retail Banking
data:image/s3,"s3://crabby-images/00dd3/00dd38900314282f00dfb63f245303987fc09781" alt=""
data:image/s3,"s3://crabby-images/bb363/bb363728a989a61e073c6a2026b4f793a31332fd" alt=""
data:image/s3,"s3://crabby-images/fefd1/fefd19626c66cc6fd9ad3b69457efbaf971503d2" alt=""
data:image/s3,"s3://crabby-images/2d0da/2d0da711a34be7e8b2f1e032f28018913f3d6ee2" alt=""
- massive fake data generator
-
based on:
- JSON Schema
- faker.js, chance.js
- started in 2014
- rewritten to TS in 2016, v0.3
TypeScript
-
typed superset of JavaScript
function objectRange(obj, times) {
...
}
function objectRange(obj: Object, times: number) {
...
}
function objectRange(obj: Object, times: number): Object[] {
...
}
module myModule {
function objectRange(obj: Object, times: number): Object[] {
...
}
...
}
-
new language, transpiled to JS
-
classes, interfaces, modules, generics
- inherited from Java/.Net -
runtime & compile-time
-
maintained by Microsoft & Google
module myModule {
interface Person {
name: string;
age: number;
}
class MyClass {
private varA: typeA;
constructor(varB: typeB) {...}
public objectRange(obj: Object, times: number): Object[] {
...
}
}
...
}
function objectRange<T>(obj: T, times: number): T[] {
var result: T[] = [];
for (var i = 0; i < times; i++) {
result.push(obj);
}
return result;
}
module cash {
export interface Payment {
amount: number;
account: string;
}
}
var payments = objectRange<cash.Payment>({
"amount":12.34,
"account": "1234 5678 90"
}, 5);
console.log(payments);
function objectRange<T>(obj: T, times: number): T[];
module cash {
export interface Payment {
amount: number;
account: string;
}
}
- weak typing
- strong typing
TypeScript
- weak typing
- asynchronous,
single-threaded
- functional
programming
- both clients and servers
- object oriented programming
- class-based
=
- asynchronous,
single-threaded
- functional
programming
- both clients and servers
- prototype-based
- class-based
- synchronous/parallel mainly
- object oriented programming
- server-side
- dynamic typing
- static typing
- static typing
JavaScript
Java
+
JavaScript Fatigue
data:image/s3,"s3://crabby-images/f6337/f63379e9edb52249d06ea08111fb179c4df5c247" alt=""
data:image/s3,"s3://crabby-images/5d3a7/5d3a79f98bad08f1053bbe65ce0885405200806f" alt=""
data:image/s3,"s3://crabby-images/dd33b/dd33b3b13281909fdaec6479c2ae81e91bbd5930" alt=""
x
data:image/s3,"s3://crabby-images/779bd/779bd5ee8521202280b10024b561a8a4636fd745" alt=""
data:image/s3,"s3://crabby-images/5310e/5310ea3bb3a93c53d98d55f52e3a416aee788f6e" alt=""
data:image/s3,"s3://crabby-images/8523c/8523ca92400b983fae151d1193f1108b29b987eb" alt=""
data:image/s3,"s3://crabby-images/de17f/de17f6bcae1039773a110f9e35ec1e1180eb317b" alt=""
data:image/s3,"s3://crabby-images/51737/51737994075b65ce5a2a7c283cf365991204ce04" alt=""
data:image/s3,"s3://crabby-images/7f0d2/7f0d291f04c0ef87e121d9d455bcf126544962a8" alt=""
data:image/s3,"s3://crabby-images/38acd/38acd9c0e7c91f9bc205045ec00ebe69f59324a3" alt=""
data:image/s3,"s3://crabby-images/86884/868843b9763bcea2b374cfb957fa7a65dcca1861" alt=""
data:image/s3,"s3://crabby-images/b5c3d/b5c3d73726828e73f20fcedf7a65d120b7d3ddff" alt=""
data:image/s3,"s3://crabby-images/fa985/fa985bee3e3ca628f13ad471de8b8408eedaaa94" alt=""
data:image/s3,"s3://crabby-images/c1c2a/c1c2a013e94111bb87be99c3b11eb4deda0e4700" alt=""
x
data:image/s3,"s3://crabby-images/5d910/5d910aea53505eb76a49e62c30f1cc075b50fe2e" alt=""
data:image/s3,"s3://crabby-images/bb537/bb53764e1d09154b5c9909375b9339889cac2588" alt=""
data:image/s3,"s3://crabby-images/cfadb/cfadb8f38a78fbdfee894d87b10f4b2bcfdc2f8d" alt=""
data:image/s3,"s3://crabby-images/cce95/cce95df5a9d8cfedc32f02db2c99140f6dc4739d" alt=""
x
data:image/s3,"s3://crabby-images/b9caa/b9caa6248d961370e3d2a139ea9bcb04adb05dfb" alt=""
data:image/s3,"s3://crabby-images/40fa4/40fa45fa9d48fdbe4e2a3ca32fb15e34fe27e906" alt=""
data:image/s3,"s3://crabby-images/ecee9/ecee9af809cdadfb0b0e78a8181774d82f48abed" alt=""
data:image/s3,"s3://crabby-images/bb7b8/bb7b85e36dbc5a75a3183a9a8d26536a0ba58e50" alt=""
data:image/s3,"s3://crabby-images/07453/074533f5c53ca81560c07e55d1b7f86b15f3e8dd" alt=""
x
data:image/s3,"s3://crabby-images/11fc0/11fc0eb0c05b37c55fd3a7b32a1081472106b71e" alt=""
data:image/s3,"s3://crabby-images/c3a10/c3a10d9570dc05033088830c289f97e84b40a8af" alt=""
data:image/s3,"s3://crabby-images/d78e0/d78e0315935566e7409365d7de9b21098ad787fd" alt=""
data:image/s3,"s3://crabby-images/50d53/50d537bf915c5b4a7d0b047f4a5ac0948eb2242f" alt=""
data:image/s3,"s3://crabby-images/9e4dc/9e4dc31e86afb17203221149ce9534a04ce5ac3e" alt=""
data:image/s3,"s3://crabby-images/6237e/6237e8a1a924b8f3989e8db70fdba5177c2c6cd3" alt=""
data:image/s3,"s3://crabby-images/e7b31/e7b314ecb988e49ea351c50d33b4b7538df95fb5" alt=""
data:image/s3,"s3://crabby-images/d4cfe/d4cfedfa78a6a6d7f75a19bb117dcd4933a17a42" alt=""
data:image/s3,"s3://crabby-images/be116/be116cf34f11e9c5c93a6900427a7cc55d428b6b" alt=""
data:image/s3,"s3://crabby-images/5e0a5/5e0a55f2952e0e58c31425f842ce436aefeef30f" alt=""
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""
data:image/s3,"s3://crabby-images/5917d/5917dc8e7f4fd3fce015a8ee9ce23c8dc8f974bd" alt=""
data:image/s3,"s3://crabby-images/4a832/4a832a3faf27b046d6312cf7f085c0fb339cfe92" alt=""
data:image/s3,"s3://crabby-images/01764/0176405d40b9693b2d4a0f3360f93217515035c9" alt=""
data:image/s3,"s3://crabby-images/4d3d1/4d3d119ca28e08a2ce48623b3f05e2e5cba195ea" alt=""
data:image/s3,"s3://crabby-images/24e1c/24e1c0ad953818cc4ac78206adea9ec12e59ac84" alt=""
data:image/s3,"s3://crabby-images/17357/17357484b083373836e4ba6b5f9327e5b4179232" alt=""
data:image/s3,"s3://crabby-images/cdc13/cdc13db55719aebdb28beb81d6d08a1424a7554a" alt=""
data:image/s3,"s3://crabby-images/dc6fe/dc6feb52235060511bba533bbc5f9a4d09aa6c85" alt=""
data:image/s3,"s3://crabby-images/2bc92/2bc925dc0ed71576ee49302e48ff8db4ff27cb9b" alt=""
data:image/s3,"s3://crabby-images/ef48f/ef48f91d06d2f07f701af474a26355b4b794ee36" alt=""
data:image/s3,"s3://crabby-images/3348e/3348e99b1acfe7bd7dd2ae13fafa22239f784b4f" alt=""
cool kids fighting
for their frameworks
data:image/s3,"s3://crabby-images/307fb/307fbdbb4978520c923cf0e294461e3e0b13dd85" alt=""
think about the problems you solve,
NOT the tools
data:image/s3,"s3://crabby-images/ac545/ac545b1ee6919180ec98a1044572971d901f7705" alt=""
~98% aware of TS existence
~72% doesn't know TS / only ~28% does
~53% interested in learning / ~47% not
data:image/s3,"s3://crabby-images/0d185/0d1858a5e863fd0c93397b2b4a04faf6ea59e439" alt=""
~85% satisfaction with TS
data:image/s3,"s3://crabby-images/5917d/5917dc8e7f4fd3fce015a8ee9ce23c8dc8f974bd" alt=""
data:image/s3,"s3://crabby-images/3f206/3f206e682d13040e0eccf6671d5453c38186ea34" alt=""
just what I wanted to say is, please try not introduce new technologies and thereby complexities without having a good reason to do so... For now we have a lot to cope with, So if you guys keep racing then we don't have a chance to get somehow on the same boat.
a colleague from my project
why should I use ?
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""
-
because I've got classes!
-
because I've got types!
-
because I shift some responsibility onto the platform!
data:image/s3,"s3://crabby-images/f2ce6/f2ce6b4dc7f7c03c008b0807090b6a4261c193c4" alt=""
the purpose of a programming language is to aid programmers in producing error-free programs
data:image/s3,"s3://crabby-images/4db32/4db32c8e3c0944a76fdaabae40431f1a50a473b6" alt=""
problems TS
solves
1. checks types
data:image/s3,"s3://crabby-images/0b5de/0b5de45f0148947ddf9bdf2c34e7a8bdf4f8a018" alt=""
test.ts(5,5): error TS2345: Argument of type 'string'
is not assignable to parameter of type 'number'.
type time
!!!
Primitive types
string
number
boolean
var a: boolean;
let f = false;
const t: boolean = true;
var a: number = 5;
let b: number;
const c = 20;
var a: string = 'John';
let name: string = `${a}`;
const c = "training";
array
var boolList: Array<boolean>
let boolList: boolean[]
const cList: boolean[] = [];
cList.push(true);
same
const
as ES6
Function types
function fullName(first, last) {
return first + ' ' + last;
}
function fullName(first, last): string {
return first + ' ' + last;
}
function fullName(first: string, last: string) {
return first + ' ' + last;
}
function fullName(first: string, last: string): string {
return first + ' ' + last;
}
nowhere
return
params
both
type Oper = (a: number, b: number) => number;
const add: Oper = (a, b) => a + b;
const sub: Oper = (a, b) => a - b;
const mul: Oper = (a, b) => a * b;
const div: Oper = (a, b) => a / b;
get(url: string,
data?: Object|string,
success?: (data: any, textStatus: string, jqXHR: JQueryXHR) => any,
dataType?: string
): JQueryXHR
priceless for defining callbacks
jQuery.get(...)
type
Function types
interface Person {
first: string;
last: string;
}
interface Person {
first: string; // required
last: string; // required
age?: number; // optional
}
interface Address {
city: string;
country: string;
postcode?: string;
}
interface Person {
first: string; // required
last: string; // required
age?: number; // optional
addresses: Address[];
}
C-style structs
contracts
Interfaces
type Currency =
"EUR" | "GBP" | "USD" | "AUD" | "CAD";
type Season =
"spring" | "summer" | "autumn" | "winter";
typedefs
let currentSeason: Season = "autumn"
currentSeason = "cucumber" // ERROR
String literal types
Tuples
type Currency =
"EUR" | "GBP" | "USD" | "AUD" | "CAD" | "NZD"
type MoneyTuple = [number, string]
let m: MoneyTuple = [4.99, "EUR"]
type MoneyTuple = [number, Currency]
let m1: MoneyTuple = [4.99, "EUR"]
let m2: MoneyTuple = [4.99, "PLN"] // ERROR
non-string enumerables
enum Directions {
Up, Down, Left, Right
}
lets moves: Directions[] = [
Directions.Right
Directions.Up,
Directions.Right
Directions.Left,
Directions.Up,
Directions.Up,
Directions.Up,
Directions.Left,
Directions.Down,
Directions.Up,
Directions.Left,
Directions.Down,
];
C-style enums
data:image/s3,"s3://crabby-images/b4fdb/b4fdbef63b14a9422d9081fbb17f94451ef8890a" alt=""
Enums
interface IPerson {
firstName: string,
lastName: string
}
type PersonString = string
type PersonTuple = [string, string]
type UberPerson = IPerson
| PersonString
| PersonTuple
function greet(person: UberPerson) {...}
greet("John Lennon")
greet(["John", "Lennon"])
greet(["John", "Lennon", 40]) // ERROR
greet({ firstName: "John", lastName: "Lennon" })
greet({ firstName: "John", lastName: "Lennon", age: 40 }) // ERROR
Unions
Intersections
interface Person {
first: string;
last: string;
age?: number;
}
interface Citizen {
regNo: string;
bankAccount: string;
}
const john: Person & Citizen = {
first: "John",
last: "Lennon",
regNo: "957204578204",
bankAccount: "94 9834 0956 1238 5499"
}
problems TS
solves
3. less unit tests
assert.isString
assert.isNumber
assert.isBoolean
problem exists in all weakly-typed languages
2. less runtime bugs
problems TS
solves
4. self-documenting
interface AccountingSummary {
id: string;
items: AccoutningItem[];
price: Amount;
signedBy?: Employee;
submittedBy?: Employee;
}
class Department {
public generateSummary(...): AccountingSummary {
... // long method
};
...
}
problems TS
solves
5. type inference
let foo = 123;
let bar = "Hello";
let foo = 123; // foo is a `number`
let bar = "Hello"; // bar is a `string`
foo = bar;
// Error: cannot assign
// `string` to a `number`
let foo = 123; // foo is a `number`
let bar = "Hello"; // bar is a `string`
problems TS
solves
6. reduces JS pitfalls
// JS
var a = 4;
var b = 5;
var c = a * b;
// c == 20
// JS
var a = "hello";
var b = "world";
var c = a * b;
// c == NaN
// TS
var a: string = "hello";
var b: string = "world";
var c: string = a * b;
// TS
var a = "hello";
var b = "world";
var c = a * b;
test.ts(4,5): error TS2322: Type 'number' is not assignable to
type 'string'.
test.ts(4,17): error TS2362: The left-hand side of an arithmetic
operation must be of type 'any', 'number' or an enum type.
test.ts(4,21): error TS2363: The right-hand side of an arithmetic
operation must be of type 'any', 'number' or an enum type.
problems TS
solves
7. disables JS hacks
var mod = null;
function logic(){
... use `mod` here
}
module.exports = function(){
mod = mod || require('MODULE');
return logic.apply(...);
}
?
var mod = require('MODULE');
module.exports = function logic(){
... use `mod` here
}
problems TS
solves
8. native modules
module outer {
var str = "hello world";
module inner {
var num = 6;
}
}
var outer;
(function (outer) {
var str = "hello world";
var inner;
(function (inner) {
var num = 6;
})(inner || (inner = {}));
})(outer || (outer = {}));
problems TS
solves
9. big business logic under control
Design Patterns
Domain Driven Design
class ThatDoesSomething {
public mainPromise: ng.IPromise<IUser[]>;
public users: IUser[];
private fetchUsers(): ng.IPromise<IUser[]> {
return UserModel.getUsers(params)
.then((response: IUser[]) => {
this.users = response;
});
}
public $onInit(): void {
this.mainPromise = this.fetchUsers();
}
}
Typed Promises
class UserModel {
public getUsers(params: ...): ng.IPromise<IUser[]> {
return Restangular.get('users');
}
}
var promise = Promise(); // of what ???
promise.then(function(???){
data = ???
})
Low-level Refactoring
CORE
M1
M2
M3
change or extend
var price = 7.99;
var price = {
amount: 7.99,
currency: "PLN"
};
Value Objects
declare type Price = number;
interface Price {
amount: number;
}
interface Price {
amount: number;
currency: string;
}
data:image/s3,"s3://crabby-images/a682a/a682aec6ef52603e76ca0e85b4b26ffe37853ea7" alt=""
Communication Contract
Data Transfer Objects
// GET /customers/{id}
interface Customer {
firstName: string;
lastName: string;
age: number;
}
Data Transfer Objects
Data Transfer Objects
// GET /customers
// GET /customers/{id}
interface Customer {
firstName: string;
lastName: string;
age: number;
}
declare type CustomerList = Customer[];
Data Transfer Objects
// GET /customers
// GET /customers/{id}
// GET /customers/{id}/addresses
interface Address {
street: string;
city: string;
country: string;
}
interface Customer {
...
addresses: Address[];
}
Data Transfer Objects
getAsyncData({
url: "/customers/<id>"
method: "GET",
...
}, function(customer: Customer): void {
process(customer.firstName); // ok
process(customer.lastName); // ok
process(customer.name); // ERROR!!!
});
problems TS
doesn't solve
data:image/s3,"s3://crabby-images/726b3/726b383f506d80e0d6f0570625d02020e29b0be8" alt=""
1. mistakes
- logical mistakes
- lack of knowledge
- asynchronous errors
(e.g. race conditions)
problems TS
doesn't solve
data:image/s3,"s3://crabby-images/85302/85302ac18377cfea2e029314c6c88ba8fd1fad77" alt=""
2. still need to understand JS
- writing TS without knowing JS == disaster
- what output will TS provide?
- read code in terms of both: OOP and async runtime
problems TS
doesn't solve
data:image/s3,"s3://crabby-images/5ce08/5ce082b556751502b4d717c33289d639960c9d2c" alt=""
3. won't make it faster
- won't make you code faster
- won't make app run faster
- actually, will slow both down just a little bit
- TS might produce more code than pure JS (modules, classes)
problems TS
doesn't solve
data:image/s3,"s3://crabby-images/8ff20/8ff20bfcb88836b5b66f6a51ae13333d72d0db15" alt=""
4. the any type
- stands for NO TYPE
- very easy to use
- very messy to use
- it's very tempting
- sometimes just can't do without
- will spoil your app if used in big amounts
- just like donuts...
var a: any = ... // EXPLICIT any
// a - INFERRED
// b - IMPLICIT any
function doSomething(a, b){
a.push(b);
}
data:image/s3,"s3://crabby-images/307fb/307fbdbb4978520c923cf0e294461e3e0b13dd85" alt=""
nothing comes for free
problems TS
introduces
1. automation becomes
more expensive
data:image/s3,"s3://crabby-images/708e8/708e8adab70bada51cdc88c99fe0b14374941e6d" alt=""
- need to transpile TS down to JS
- big project = big cost
- blockers included
problems TS
introduces
2. compatibility with
3rd party libs
data:image/s3,"s3://crabby-images/1c6e9/1c6e9b8b30b54443c1154d4443e8ab08f6d6e628" alt=""
- DefinitelyTyped
- less popular projects lack .d.ts files
problems TS
introduces
3. your teammates need to learn
data:image/s3,"s3://crabby-images/0b725/0b725976e0649fe0038e8e02d2fa8de848374362" alt=""
- probably you'll teach them
- entry level is quite low
problems TS
introduces
4. debugging less convenient
data:image/s3,"s3://crabby-images/548e2/548e2c50d7d0f84085abb3d54f695d6b0a9d61a0" alt=""
- browsers don't execute TS
- source and output: different
problems TS
introduces
automation
more expensive
data:image/s3,"s3://crabby-images/708e8/708e8adab70bada51cdc88c99fe0b14374941e6d" alt=""
data:image/s3,"s3://crabby-images/1c6e9/1c6e9b8b30b54443c1154d4443e8ab08f6d6e628" alt=""
3rd party libs compatibility
data:image/s3,"s3://crabby-images/0b725/0b725976e0649fe0038e8e02d2fa8de848374362" alt=""
teach people
data:image/s3,"s3://crabby-images/548e2/548e2c50d7d0f84085abb3d54f695d6b0a9d61a0" alt=""
debugging less convenient
writing JavaScript is not trendy anymore
data:image/s3,"s3://crabby-images/d4cfe/d4cfedfa78a6a6d7f75a19bb117dcd4933a17a42" alt=""
data:image/s3,"s3://crabby-images/be116/be116cf34f11e9c5c93a6900427a7cc55d428b6b" alt=""
data:image/s3,"s3://crabby-images/5e0a5/5e0a55f2952e0e58c31425f842ce436aefeef30f" alt=""
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""
JS
vs
ES6
vs
TS
data:image/s3,"s3://crabby-images/ffefe/ffefe05def9b155a95893505f93a6106fbeb85ea" alt=""
data:image/s3,"s3://crabby-images/20b52/20b52c80a6cfeddf8eb553902d5bb5071b7faacd" alt=""
data:image/s3,"s3://crabby-images/0a88c/0a88cd144b565466ff8a2e70415d734edfa6db6f" alt=""
data:image/s3,"s3://crabby-images/e6712/e6712a556a761dd83061e2dd71ecb5c034d923fc" alt=""
writing TypeScript is not trendy anymore
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""
data:image/s3,"s3://crabby-images/75dcc/75dcc25f7a730361b86dcb403ab5ee81d1a4f137" alt=""
data:image/s3,"s3://crabby-images/d232b/d232be5662045caa07141e7a74b4a7c22ae84348" alt=""
choose TypeScript for development of any new project
when is it worth to go TS?
data:image/s3,"s3://crabby-images/ff7b4/ff7b4c0b67a264802a20b830738ea01b8f2631b4" alt=""
project?
people?
- size, codebase
- domain complexity
- open for changes
- non-dogmatic attitude
technical dogma example
JavaScript shall always remain dynamically typed
data:image/s3,"s3://crabby-images/c9aad/c9aada1c9750e4966a164e5a14093962a8ffacb1" alt=""
data:image/s3,"s3://crabby-images/307fb/307fbdbb4978520c923cf0e294461e3e0b13dd85" alt=""
all decisions have pros and cons
transpiling JS
pros & cons
data:image/s3,"s3://crabby-images/1cd88/1cd882e2fd689ef89d2d9dcfae042e8281b6e434" alt=""
- more features
- might be less code
- efficiency
- following trends
- more code complexity
- higher entry-level
for BE & junior devs - IDE support needed
- more setup complex
value of the new features
costs of introducing it
>
?
data:image/s3,"s3://crabby-images/307fb/307fbdbb4978520c923cf0e294461e3e0b13dd85" alt=""
think about the problems you solve, NOT the tools
always be responsible for the tools you introduce
nothing comes for free
all decisions have pros and cons
THX!
data:image/s3,"s3://crabby-images/0277a/0277aa02cfe72fe2640503d17716004a97524e41" alt=""
4 Q&A
data:image/s3,"s3://crabby-images/bdd9c/bdd9cdf74f51872bb9c9beb60f84adbc53e48526" alt=""
writing JavaScript is not trendy anymore ;)
data:image/s3,"s3://crabby-images/d4cfe/d4cfedfa78a6a6d7f75a19bb117dcd4933a17a42" alt=""
data:image/s3,"s3://crabby-images/be116/be116cf34f11e9c5c93a6900427a7cc55d428b6b" alt=""
data:image/s3,"s3://crabby-images/5e0a5/5e0a55f2952e0e58c31425f842ce436aefeef30f" alt=""
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""
ES6
- arrows
- classes
- enhanced object literals
- template strings
- destructuring
- default + rest + spread
- let + const
- iterators + for..of
- generators
- unicode
- modules
- module loaders
- map + set + weakmap + weakset
- proxies
- symbols
- subclassable built-ins
- promises
- math + number + string + array + object APIs
- binary and octal literals
- reflect api
- tail calls
TypeScript
- most of what ES6 has
-
type checks
- templates typecheck
( ongoing) - TS -> ES6 (ongoing)
CoffeeScript syntax
# Assignment:
number = 42
opposite = true
# Conditions:
number = -42 if opposite
# Functions:
square = (x) -> x * x
# Arrays:
list = [1, 2, 3, 4, 5]
var list, number, opposite, square;
number = 42;
opposite = true;
if (opposite) {
number = -42;
}
square = function(x) {
return x * x;
};
list = [1, 2, 3, 4, 5];
CoffeeScript syntax
# Splats:
race = (winner, runners...) ->
print winner, runners
var race,
slice = [].slice;
race = function() {
var runners, winner;
winner = arguments[0],
runners = 2 <= arguments.length ?
slice.call(arguments, 1) : [];
return print(winner, runners);
};
CoffeeScript usecase
class DataWidgetCtrl
fetchData: ->
@$timeout =>
@table.loaded = true
resourceObject = angular.fromJson(@$attrs.resource)
model = @$injector.get(resourceObject.model)
@table.promise = model[resourceObject.method](resourceObject.id).then (res) =>
@setData(res)
@init()
, (res) =>
@getHeader(@def.i18n, @table)
@table.error = res.status
, 0
...
var DataWidgetCtrl;
DataWidgetCtrl = (function() {
DataWidgetCtrl.prototype.fetchData = function() {
return this.$timeout((function(_this) {
return function() {
var model, resourceObject;
_this.table.loaded = true;
resourceObject = angular.fromJson(_this.$attrs.resource);
model = _this.$injector.get(resourceObject.model);
return _this.table.promise = model[resourceObject.method]
(resourceObject.id).then(function(res) {
_this.setData(res);
return _this.init();
}, function(res) {
_this.getHeader(_this.def.i18n, _this.table);
return _this.table.error = res.status;
});
};
})(this), 0);
};
...
return DataWidgetCtrl;
})();
writing JavaScript is not trendy anymore ;)
data:image/s3,"s3://crabby-images/d4cfe/d4cfedfa78a6a6d7f75a19bb117dcd4933a17a42" alt=""
data:image/s3,"s3://crabby-images/be116/be116cf34f11e9c5c93a6900427a7cc55d428b6b" alt=""
data:image/s3,"s3://crabby-images/5e0a5/5e0a55f2952e0e58c31425f842ce436aefeef30f" alt=""
data:image/s3,"s3://crabby-images/a276c/a276cdd472b681af32c2c1e557487bafecebd780" alt=""