ES6 syntactic sugar you should be using today
@sebastianmisch
ES6=
ECMAScript2015=
next-gen Javascript
sa' wut?
Use ES6 in
- Chrome
- Latest Firefoxes
- and... Edge!
But what about the old school browsers?
TRANSPILE!
and dance.
Arrow functions
// ES5
[ 1, 2, 3, 4, 5 ].filter(function(x) { return x % 2 === 0; })
// [ 2, 4 ]
// ES6
[ 1, 2, 3, 4, 5 ].filter((x) => { return x % 2 === 0; })
// [ 2, 4 ]
[ 1, 2, 3, 4, 5 ].filter(x => { return x % 2 === 0; })
// [ 2, 4 ]
[ 1, 2, 3, 4, 5 ].filter(x => x % 2 === 0)
// [ 2, 4 ]
Template strings
// ES5
'Hello, my name is ' + name + '!'
// Hello my name is Paul!
'Hello, my name is ' + name + '!\nI live in Berlin.'
// ES6
`Hello, my name is ${name}!`
// Hello my name is Paul!
`Hello, my name is ${name}!
I live in Berlin.`
// Hello my name is Paul!
// I live in Berlin.
Nifty string shorthands
// ES5
'Hello Paul!'.indexOf('Paul') > -1
// true
// ES6
'Hello Paul!'.includes("Paul")
// true
// ES5
var i, s = '';
for (i = 0; i < 3; ++i) {
s = s + 'Hello!';
}
// s = 'Hello!Hello!Hello!'
// ES6
let s = 'Hello!'.repeat(3);
// s = 'Hello!Hello!Hello!'
Array love!
[ 0, 0, 0, 0, 0, 0 ].fill(42, 3)
// [ 0, 0, 0, 42, 42, 42 ]
[ 1, 2, 4, 8, 16 ].find(x => x > 2)
// 4
[ 1, 2, 4, 8, 16 ].findIndex(x => x > 2)
// 2
[ 1, 2, 4, 8, 16 ].copyWithin(3, 0)
// [ 1, 2, 4, 1, 2 ]
Promises!
// ES6
function waitOneSecond() {
return new Promise((resolve, reject) => {
setTimeout(resolve, 1000);
});
}
waitOneSecond().then(() => {
console.log('Hello after one second!');
});
// Promise { <pending> }
// Outputs 'Hello...' after one second asynchronously
Destructuring
// ES6
var [odd, even, , four] = [ 1, 2, 3, 4 ];
// odd = 1
// even = 2
// four = 4
function hello({name: x}) {
console.log(`Hello, my name is ${x}!`);
}
hello({age: 26, name: 'Paul'});
// Hello, my name is Paul!
Defaulting
// ES6
function iLike(what = 'cats') {
console.log(`I like ${what}!`);
}
iLike('ES6');
// I like ES6!
iLike();
// I like cats!
Rest parameters
// ES6
function countParameters(first, ...allOthers) {
console.log(1 + allOthers.length);
}
countParameters(1, 2, 3, 4);
// 4
Spread parameters
// ES6
function firstThree(first, second, third) {
console.log(first, second, third);
}
firstThree(...[ 1, 2, 3, 4 ]);
// 1 2 3
Scoping with let & const
// ES5
var foo = 1;
// foo = 1
// ES6
let foo = 1;
// foo = 1
const bar = { name: 'Paul' };
// bar = { name: 'Paul' }
bar = { other: 'stuff' };
// error
bar.name = 'Felix';
// bar = { name: 'Felix' }
// ES5
(function scope() {
console.log(a);
var a = 1;
})()
// undefined
// ES6
(function scope() {
console.log(a);
let a = 2;
})()
// ReferenceError
why
use
ES6?
because you can 🍺
ES6 syntactic sugar you should be using today
By Sebastian Misch
ES6 syntactic sugar you should be using today
A brief introduction into new features of ES6
- 1,646