6 Exciting Features of ES6
Seema Ullal
seemaisms
"CLASSES"
ES5
function Rectangle(l,w) {
Shape.call(this);
this.length = l;
this.width = w;
}
Rectangle.prototype.area = function() {
return this.length * this.width;
}
//instantiating the class
var myRectangle = new Rectangle(3,4);
myRectangle.area() //returns 12
CLASSES
ES6
class Rectangle extends Shape { // inheritance!
constructor(l,w) {
super(); //calls the Shape constructor
this.length = l;
this.width = w;
}
this.area(){
return this.length * this.width;
}
}
Arrows
ES5
var nums = [1,2,3,4];
nums.map(function(number) {
return number * 2;
});
ES6
var nums = [1,2,3,4];
nums.map(number => number *2);
LEXICAL THIS
function Timer() {
this.time = 0;
var self = this;
setInterval(function() {
console.log(self.time++);
}, 1000)
}
No more of this weirdness
ES6 for the win
function Timer() {
this.time = 0;
setInterval(() => {
//maintains the outer scope
console.log(this.time++);
}, 1000)
}
BLOCK SCOPING
//the scope of i is limited to inside the loop
for (let i = 0; i < 10; i++) {
num += i;
console.log('value of i in block: ' + i);
}
console.log(i) //will be undefined
Template strings
var name = "Seema";
//prints "My name is Seema"
console.log(`My name is ${name}`);
//prints "SEEMA"
console.log(`${name.toUpperCase()}`
var str = `You
definitely
can\'t do
this
in ES5`
BUIlt-in Promises
function timeout(duration = 0) { //default value of 0
return new Promise((resolve, reject) => {
setTimeout(resolve, duration);
})
}
var p = timeout(1000).then(() => {
return timeout(2000);
}).then(() => {
throw new Error("hmm");
}).catch(err => {
return Promise.all([timeout(100), timeout(200)]);
})
...and much more!
- Generators
- Iterators
- Modules
- Maps and Sets
...
learn more
Seema Ullal
seemaullal@gmail.com
seemaisms