preface

ES6 is the standard for upcoming versions of the JavaScript language, and it brings us more “sweet” syntaxes (syntaxes that make the language easier to understand and read, and make it easier and faster to write code), such as arrow functions (=>), classes, and so on. In a word:

ES6 gives us a lot of new syntax and code features to improve the javascript experience

Unfortunately, there is no browser that supports es6 syntax well, so we need to use Babel to convert to CommonJS as a modular standard.

Since I’m going to cover some examples of the new ES6 features below, if you want to try them out, you can click here to test the ES6 code.

Common ES6 features

I’ll then briefly introduce some of the most commonly used syntax features, which I recommend if you want a complete overview of ES6

Define a function

Let’s start with a basic new feature. In javascript, you need the keyword function to define functions, but in ES6, there are more advanced ways to write functions. Let’s look at:

Es6 writing:

Var human = {breathe(name) {// Breathe without function. console.log(name + ' is breathing... '); }}; human.breathe('jarson'); // 'Jarson is Breathing... 'Copy the code

Convert to js code:

var human = {
    breathe: function(name) {
        console.log(name + 'is breathing...');
    }
};
human.breathe('jarson');Copy the code

Amazing, isn’t it? By contrast, es6 is easy to write. Don’t worry, there’s more to it.

Create a class

As we know, javascript is not an object-oriented programming language like Java, but only an object-based programming language. So in JS, we usually use function and prototype to simulate the concept of classes.

But now, with ES6, we can create a class “blatantly” like Java:

class Human {
    constructor(name) {
        this.name = name;
    }
    breathe() {
        console.log(this.name + " is breathing");
    }
} 
var man = new Human("jarson");
man.breathe();    //jarson is breathingCopy the code

Convert the above code to JS format:

function Human(name) {
    this.name = name;
    this.breathe = function() {
        console.log(this.name + ' is breathing');
    }
}
var man = new Human('jarson');
man.breathe();    //jarson is breathingCopy the code

So we see that we can create a class semantically like Java. In addition, js inheritance parent class, need to use prototype to implement. So what are the new ways to implement class inheritance in ES6? Continue to look at:

If we want to create a Man class that inherits the Human class above, es6 code:

class Man extends Human {
    constructor(name, sex) {
        super(name);
        this.sex = sex;
    }
    info(){
        console.log(this.name + 'is ' + this.sex);
    }
}
var xx = new Man('jarson', 'boy');
xx.breathe();   //jarson is breathing
xx.info();   //arsonis boyCopy the code

The code is so simple that you can use one of the online tools mentioned in this article to try it out. Note that super() is the constructor of the parent class.

The module

Javascript natively supports Modules in the ES6 standard. To write the codes of different functions in different files, each module only needs to export the public interface part, and then import the module where it needs to be used. Here’s another example:

Inline export

Objects in an ES6 module can be exported directly in the declaration that creates them, and export can be used countless times in a module.

Look at the module file app.js:

export class Human{
    constructor(name) {
        this.name = name;
    }
    breathe() {
        console.log(this.name + " is breathing");
    } 
}  
export function run(){  
    console.log('i am runing'); 
}
function eat() {
    console.log('i am eating');
}Copy the code

The module in this example exports two objects: the Human class and the run function. If the eat function is not exported, it is still private to the module and cannot be used by other files.

Export a set of objects

In addition, if we need to export a lot of objects, we can export a group of objects at the end.

Change the app.js file:

class Human{
    constructor(name) {
        this.name = name;
    }
    breathe() {
        console.log(this.name + " is breathing");
    } 
}  
function run(){  
    console.log('i am runing'); 
}
function eat() {
    console.log('i am eating');
}
export {Human, run}; Copy the code

This works the same as above, but it’s also obvious at the end that you can clearly see which objects are exported.

The Default is derived

When exporting an object, use the keyword default to export the object as default. The default keyword can only be used once in each module. It can be used either inline exports or in a set of object export declarations.

See the syntax for exporting the default object:

. Export default {// Label Human and run as default objects. Human, run };Copy the code

None Object import

If a module contains some logic to execute and no objects are exported, such objects can also be imported into another module, after which only the logic is executed. Such as:

import './module1.js'; Copy the code

Importing default objects

Use the Default export mode to export objects that are directly assigned to a reference in the import statement, as in the following example “app”.

import app from './module1.js'; Copy the code

In the example above, the default./module1.js file exports only one object; If you export a set of objects, you should list them in the import declaration as follows:

import {Human, run} from './app.js'Copy the code

Let the const

In my opinion, in the new ES6 feature, let should be used instead of var when defining variables. Const is intuitive and is used to define constants, i.e. variables whose value cannot be changed.

for (let i=0; i<2; i++) { console.log(i); // output: 0,1}Copy the code

Arrow function

The new arrow operator => in ES6 simplifies function writing. The left side of the operator is the input parameter, and the right side is the operation and the return value. This can save a lot of code.

let arr = [6, 8, 10, 20, 15, 9]; arr.forEach((item, i) => console.log(item, i)); let newArr = arr.filter((item) => (item<10)); console.log(newArr); / / [6, 8, 9];Copy the code

The (item, I) above is the argument, and the console.log(item, I) after it is the operation logic that goes back to the function.

Convert the above code to JS format:

var arr = [6, 8, 10, 20, 15, 9];
arr.forEach(function(item, i) {
    return console.log(item, i);
});
var newArr = arr.filter(function(item) {
    return (item < 10);
});
console.log(newArr);Copy the code

String template

In ES6, it is possible to create strings using backquotes, which can contain the variable ${vraible} wrapped in dollar signs and curly braces. Take a look at an example:

// generate a random number let num = math.random (); Log (' your num is ${num} ');Copy the code

deconstruction

If a function returns multiple values, the conventional approach is to return an object, each value as an attribute of that object. In ES6, with the deconstruction feature, you can return an array directly, and the value in the array is automatically parsed into the corresponding variable that receives the value. Let’s take an example:

function getVal() { return [1, 2]; } var [x,y] = getVal(); // Destruct console.log('x:'+x+', y:'+y); // Output: x:1, y:2Copy the code

The default parameters

You can now specify default values for parameters when you define functions, rather than using logic or operators as before.

function sayHello(name){ var name=name||'tom'; // The traditional way of specifying default arguments console.log('Hello '+name); } function sayHello2(name=' Tom '){console.log(' Hello ${name} '); } sayHello(); // Output: Hello Tom sayHello('jarson'); Hello jarson sayHello2(); // Output: Hello Tom sayHello2('jarson'); // Output: Hello JarsonCopy the code

SayHello2 (name=’ Tom ‘) = sayHello2(name=’ Tom ‘)

Proxy

The Proxy can listen for things to happen to objects and perform actions when those things happen. All of a sudden it gives us great traceability to an object, and it’s also useful for data binding.

Let engineer = {name: 'Joe Sixpack', salary: 50}; Let interceptor = {set(receiver, property, value) {console.log(property, 'is changed to', value); receiver[property] = value; }}; Engineer = new Proxy(Engineer, interceptor); // Make some changes to trigger agent engineer. Salary = 70; // Console output: salary is changed to 70Copy the code

In the case of a handler, a method in the handler is called after an event has occurred on the object being listened to.

conclusion

Overall, while es6 support has not been great so far, the new syntax features of ES6 make the difference between the front end and the back end smaller and smaller. This is the beginning of a new era, and we need to understand these new frontiers in order to keep up.