ESNext

revisited

http://slides.com/tuxsudo/esnext

What is ES6

ES7, ES2015, ES2016, ESNext, Etc?

EcmaScript

The specification behind JavaScript

ES Versions

Version Release Year
1 1997
2 1998
3 1999
4 Never!
5 2009
5.1 2011
6 2015
7 2016 (WIP)

So...

ES6 and ES2015 are synonymous

 

They refer to the 6th edition of the ECMAScript

released in 2015.

How are Features Added to the Spec?

TC39

The technical committee behind the specification

Includes people from:

  • ECMA International
  • Google
  • Microsoft
  • Yahoo
  • Facebook
  • AirBNB
  • Community Leaders

http://www.ecma-international.org/memento/TC39.htm

https://github.com/tc39

TC39 Process

The five-stage process to add features to the spec

https://tc39.github.io/process-document/

Stage # Stage Name Summary
0 Strawman Gather community input
1 Proposal Make the pitch
2 Draft Create formal spec/syntax
3 Candidate Field testing
4 Finished Will be part of ESNext

ESNext

before & after

let & const

  • block scoping

  • single assignment

var i = 911;

for(var i = 0; i<3; i++) {
    console.log(i);
}

console.log("Someone dial " + i);

let & const

Block Scoping

before

https://jsbin.com/gaceli/1/edit?js,console

let i = 911;

for(let i = 0; i<3; i++) {
    console.log(i);
}

console.log("Someone dial " + i);

https://jsbin.com/cusako/1/edit?js,console

let & const

Block Scoping

after

var int = 1,
    str = "String",
    arr = [1, 2, 3, 4],
    obj = {one: 1, two: 2};

int = 2;
console.log(int);

str = "";
console.log(str);

arr.push(5);
console.log(arr);

arr = [];
console.log(arr);

obj.three = 3;
console.log(obj);

obj = {};
console.log(obj);

https://jsbin.com/gatinu/3/edit?js,console

let & const

Single Assignment

before

const int = 1;
const str = "String";
const arr = [1, 2, 3, 4];
const obj = {one: 1, two: 2};

int = 2;
console.log(int);

str = "";
console.log(str);

arr.push(5);
console.log(arr);

arr = [];
console.log(arr);

obj.three = 3;
console.log(obj);

obj = {};
console.log(obj);

http://bit.ly/1PIgToS

let & const

Single Assignment

after

Template Strings

multiline and interpolated variables

var name = "simon";
var product = "drawrings";

console.log("hello my name is " + name 
    + "\nand I like to make " + product);

Multiline & Interpolated Variables

Template Strings

before

const name = "simon";
const product = "drawrings";

console.log(
`hello my name is ${name}
and I like to make ${product}`
);

https://jsbin.com/wegama/2/edit?js,console

Multiline & Interpolated Variables

Template Strings

after

Arrow Functions

  • Compact & lambda friendly syntax
  • Lexical `this`
var results = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
  .map(function(n) {
    return n*n;	
  })
  .map(function(n) {
    return n/2;	
  })
  .filter(function(n) {
    return n%1===0;
  })
  .reduce(function(last, curr) {
	return last + curr;
  }, 0);

Arrow Functions

https://jsbin.com/qidawah/5/edit?js,console

Compact Syntax

before

const results = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
  .map(n => n*n)
  .map(n => n/2)
  .filter(n => n%1===0)
  .reduce((last, curr) => last + curr, 0);

https://jsbin.com/yavema/1/edit?js,console

Arrow Functions

Compact Syntax

after

var stack1 = {
    friends: ['bruce', 'matt', 'cory'],
    traitor: 'cory',
    friendsNotTraitors: function() {
        var that = this;
        return this.friends.filter(
            function(t) {
                return that.traitor!==t;   
            }
        );     
    }
};
var stack2 = {
    friends: ['bruce', 'matt', 'cory'],
    traitor: 'cory',
    friendsNotTraitors: function() {
        return this.friends.filter(
            function(t) {
                return this.traitor!==t;   
            }.bind(this)
        );     
    }
};

or

https://jsbin.com/fofivu/3/edit?js,console

stack1.friendsNotTraitors();
stack2.friendsNotTraitors();

Arrow Functions

Lexical this

before

const stack = {
    friends: ['bruce', 'matt', 'cory'],
    traitor: 'cory',
    friendsNotTraitors: function() { 
        return this.friends.filter(t => this.traitor!==t);
    }
};
stack.friendsNotTraitors();

https://jsbin.com/zasiqo/1/edit?js,console

Arrow Functions

Lexical this

after

Enhanced Object Literals

  • shorthand prop assignment
  • shorthand methods
  • computed prop names
var toppings = ["pepperoni", "olives"],
    size = 12,
    time = 60*30;

module.exports = {
    toppings: toppings,
    size: size,
    time: time
};

Shorthand Prop Assignment

Enhanced Object Literals

before

const toppings = ["pepperoni", "olives"];
const size = 12;
const time = 60*30;

export default { toppings, size, time };

Shorthand Prop Assignment

Enhanced Object Literals

after

{
    onClick: function() {
        console.log('i clicked');
    }
};

Shorthand Methods

Enhanced Object Literals

before

{
    onClick() {
        console.log('i clicked');
    }
};

Shorthand Methods

Enhanced Object Literals

after

var name = "Jared",
    obj = {};

obj[name] = "Anderson";

Computed Prop Names

Enhanced Object Literals

before

const name = "Jared"

const obj = {
    [name]: "Anderson"
}

Computed Prop Names

Enhanced Object Literals

after

Enhanced Object Literals

http://bit.ly/1SCiX6p

Destructuring

  • array values
  • object props
  • object props renaming
  • deep destructuring
  • declarative function arguments
  • argument reassignment
var arr = ["zero", "one", "two", "three"];

var one = arr[1];
var three = arr[3];

Destructuring

Array Values

before

const arr = ["zero", "one", "two", "three"];

const [, one, , three] = arr;

Destructuring

Array Values

after

https://jsbin.com/balolaj/2/edit?js,console

var obj = {
    zero: 0,
    one: 1,
    two: 2,
    three: 3,
    four: 4,
    five: 5,
    six: 6,
    seven: 7,
    eight: 8,
    nine: 9
};

var one = obj.one;
var three = obj.three;
var five = obj.five;
var seven = obj.seven;

Destructuring

Object Props

before

const obj = {
    zero: 0,
    one: 1,
    two: 2,
    three: 3,
    four: 4,
    five: 5,
    six: 6,
    seven: 7,
    eight: 8,
    nine: 9
};

const {one, three, five, seven} = obj;

Destructuring

Object Props

after

const obj = {
    zero: 0,
    one: 1,
    two: 2,
    three: 3,
    four: 4,
    five: 5,
    six: 6,
    seven: 7,
    eight: 8,
    nine: 9
};

const {
  one: uno,
  three: tres,
  five: cinco,
  seven: siete
} = obj;

Destructuring

Object Props Renaming

after

https://jsbin.com/cicica/1/edit?js,console

var obj = {
  one: {
    eng: "one",
    spa: "uno",
    int: 1
  },
  two: {
    eng: "two",
    spa: "dos",
    int: 2
  }
};

var spanish1 = obj.one.spa;
var num2 = obj.two.int;

Destructuring

Deep Destructuring

before

const obj = {
    one: {
      eng: "one",
      spa: "uno",
      int: 1
    },
    two: {
      eng: "two",
      spa: "dos",
      int: 2
    }
};

const {
    one: {spa: spanish1},
    two: {int: num2}
} = obj;

Destructuring

Deep Destructuring

after

https://jsbin.com/satagi/1/edit?js,console

function errMsg(err) {
    return "hey "
        + err.recipient
        + ", something "
        + err.severity + " happened."
        + "\nThe message we got is: '"
        + err.message
        + "'\nThe details are: '"
        + err.details
        + "'";
}

Destructuring

Declarative Fn Args

before

const errMsg = ({recipient, severity, message, details}) =>

`hey ${recipient}, something ${severity} happened.
The message we got is: '${message}'
The details are: '${details}'`;

Destructuring

Declarative Fn Args

after

function sayHi({person: p, mood: m}) {
  console.log(`hi ${p}. why so ${m}?`);
}

Destructuring

Argument Reassignment

after

https://jsbin.com/yupaca/1/edit?js,console

Default Arguments

  • basic defaults
  • destructure defaults
  • ++destructure defaults

Default Arguments

Basic Defaults

before

function annoyParents(wheelsArg, round1Arg, round2Arg) {
    var wheels = wheelsArg || "wheels";
    var round1 = round1Arg || "round";
    var round2 = round2Arg || "round";
    var roundAndRound = " " + round1 + " and " + round2;
  
    return "The "
        + wheels
        + " on the bus go"
        + roundAndRound.repeat(3)
        + ".\nthe "
        + wheels
        + " on the bus go"
        + roundAndRound
        + " - all through the town.";
}

Default Arguments

Basic Defaults

after

function annoyParents(wheels="wheels", round1="round", round2="round") {
    const roundAndRound = ` ${round1} and ${round2}`;
  
    return `The ${wheels} on the bus go\
${roundAndRound.repeat(3)}. \
The ${wheels} on the bus go\
${roundAndRound} - all through the town.`;
}

https://jsbin.com/fuyixa/1/edit?js,console

Default Arguments

Destructure Defaults

after

function annoyParents({wheels="wheels", round1="round", round2="round"}) {
    const roundAndRound = ` ${round1} and ${round2}`;
  
    return `The ${wheels} on the bus go\
${roundAndRound.repeat(3)}. \
The ${wheels} on the bus go\
${roundAndRound} - all through the town.`;
}

https://jsbin.com/fotixu/1/edit?js,console

Default Arguments

++Destructure Defaults

after

function annoyParents({
    wheels="wheels",
    round1="round",
    round2="round"
    } = {}
) {
    const roundAndRound = ` ${round1} and ${round2}`;
  
    return `The ${wheels} on the bus go\
${roundAndRound.repeat(3)}. \
The ${wheels} on the bus go\
${roundAndRound} - all through the town.`;
}

https://jsbin.com/yimiqu/1/edit?js,console

Spread

  • Arrays
  • Objects

Spread

Arrays

before

var argsFromSomewhere = [25, 50, 25];

function add3Numbers(a, b, c) {
    return a + b + c;
}

add3Numbers.apply(null, argsFromSomewhere);

Spread

Arrays

after

var argsFromSomewhere = [25, 50, 25];

function add3Numbers(a, b, c) {
    return a + b + c;
}

add3Numbers(...argsFromSomewhere);

https://jsbin.com/duyime/1/edit?js,console

Spread

Objects

before

var obj1 = { one: 1, two: 2, three: 2};
var obj2 = { three: 3, four: 4, five: 5};


// The ES6 Way
var combined = Object.assign({}, obj1, obj2);

// most common solution:
// pull in library to merge

// jq
var combined = $.extend({}, obj1, obj2);

// underscore
var combined = _.extend({}, obj1, obj2);

Spread

Objects

after

const obj1 = { one: 1, two: 2, three: 2};
const obj2 = { three: 3, four: 4, five: 5};

const combined = {...obj1, ...obj2};

http://bit.ly/22Vy7w4

Rest Parameters

Create a pipeline function that:

  • accepts any value as its first argument
  • accepts n number functions as arguments 2, 3, 4, etc...
  • pipes the original value through all the functions, left to right.
  • returns the result...

Rest Parameters

Contrived Pipeline Example

pipeline(x, fn1, fn2, fn3, fn4, fn5)

Rest Parameters

before

function pipeline () {
    var val = arguments[0],
        fns = Array.prototype.slice.call(arguments, 1);

    return fns.reduce( function(l, c) {
        return c(l);
    }, val);
}

Contrived Pipeline Example

const pipeline = (val, ...fns) =>
  fns.reduce( (l, c) => c(l), val);

Rest Parameters

after

Contrived Pipeline Example

https://jsbin.com/tifacip/1/edit?js,console

Symbols

  • unique keys

Symbols

before

var myUniqueKey = "___uniqueish_via_obfuscation__FTL___";

Unique Keys

Symbols

after

const key = Symbol("my-key");

Unique Keys

https://jsbin.com/cakoxa/1/edit?js,console

Modules

Modules

before

// Global variables
window.globalVar = "ew";

// CommonJS+Browserify
module.exports = {}
require('something');


// SystemJS
System.import('main.js');

Modules

after

export const a = "apple";

export function isCool({ likes = [] }) {
    return likes.includes('pizza');
}

export default {
    one: 1,
    three: 3
};

a.js

import {a, isCool} from 'a.js';

b.js

import whateverNameIWant from 'a.js';

c.js

Where Can I Learn More?

Babel

https://babeljs.io/docs/learn-es2015/

Current Stage 1-4 Proposals

https://github.com/tc39/ecma262

Kangax Compat Tables

http://kangax.github.io/compat-table/esnext/

http://kangax.github.io/compat-table/es6/

Mozilla

https://hacks.mozilla.org/category/es6-in-depth/

The End

ESNext

By Jared Anderson

ESNext

  • 1,632