ES6 vs ES5总结

最近半年开始接触前端的项目,虽然之前也多多少少接触过,但也都只是蜻蜓点水,没有完全在意里面的语法和使用的场景。尤其是ES6的出现,自己脑子里的概念还是停留在ES5阶段,所以这篇文章就是帮助自己migrate from ES5 to ES6。

Template literals(模板字面量)

模板字面量不同之处在于可以嵌入表达式和字符,以前我们拼接字符用'+'来拼接,如果字符串过长就会导致很混乱,不太好维护,现在ES6可以使用${}表达式,而且可以避免部分特殊字符(\n、"、'等)的转义

ES5

var name = "Renu";

var age = 9;

console.log ("My name is \" "+ name + " \" "+ " and I 'm " + age + " years old. ")

// My name is "Renu" and I 'm 9 years old.

ES6

var name = "Renu";

var age = 9;

console.log (`My name is'" ${name} "and I'm ${age} years old.`);

// My name is "Renu" and I 'm 9years old.

Function declaration

在ES5中定义function的方法有3种:

function str (arg1, arg2) {console.log ('Renu')}
var str = new Function ("arg1", "arg2", "console.log ('Renu')");
var str = function (arg1, arg2) {console.log ('Renu');}

在ES6中使用arrow function:

var str = (arg1, arg2) => {console.log ('Renu');}

Difference if this

this关键字代表function的上下文,它决定了how you call the function, 而不是how you defined it.

ES5
在function中,this指的是the object that function belong to。

var value = 'window-value';
var showValue = function( scope ){
    console.log( 'this inside ' +  scope + ' is : ', this );
    console.log( this.value );
};
var object = {
    value: 'object-value',
    showValue: showValue
};
showValue( 'window' ); // 输出 window-value
object.showValue( 'object' );  //输出 object-value

匿名函数属于window作用域

var object = {
    provider: 'gmail.com',
    usernames: [ 'mike', 'john', 'nina' ],
    getEmails: function() {
        return this.usernames.map( function( username ){
            return username + '@' + this.provider;
        } );
    }
};
var emails = object.getEmails();
console.log( emails ); //["mike@undefined", "john@undefined", "nina@undefined"]

所以,当在匿名函数中调用 this.porvider的时候,this指向的是window,window.provider没有被定义,所以输出的结果为["mike@undefined", "john@undefined", "nina@undefined"]。如果代码修改为如下,结果就会正确:

var provider = 'yahoo.com';
var object = {
    provider: 'gmail.com',
    usernames: [ 'mike', 'john', 'nina' ],
    getEmails: function() {
        return this.usernames.map( function( username ){
            return username + '@' + this.provider;
        } );
    }
};
var emails = object.getEmails();
console.log( emails ); //["mike@yahoo.com", "john@yahoo.com", "nina@yahoo.com"]

如果想改变function的作用域,可以通过bind方法进行绑定:

var provider = 'yahoo.com';
var object = {
    provider: 'gmail.com',
    usernames: [ 'mike', 'john', 'nina' ],
    getEmails: function() {
        return this.usernames.map( function( username ){
            return username + '@' + this.provider;
        }.bind( this ) );
    }
};
var emails = object.getEmails();
console.log( emails ); //["mike@gmail.com", "john@gmail.com", "nina@gmail.com"]

因为在getEmails方法中,this指的是objectbind(this)实际是把object绑定为匿名函数的作用域

ES6
在arrow function中,{}中的this指的是whatever the value of this inside upper function is。

var provider = 'yahoo.com';
var object = {
    provider: 'gmail.com',
    usernames: [ 'mike', 'john', 'nina' ],
    getEmails: function() {
        return this.usernames.map( ( username ) => {
            return username + '@' + this.provider;
        } );
    }
};
var emails = object.getEmails();
console.log( emails );

getEmails方法中,this.usernames中的this指的是object,所以在arrow function中{}中的this.provider中的this指的是object

声明变量

var 允许定义重复的变量名
let 变量名不能重复,且变量可以修改
const 变量名不能重复,且变量不能修改

以及作用域不同

if (true) {
    var i = 0;
}
console.log (i); // 0
if (true) {
    let j = 10;
}
console.log (j); // ReferenceError
if (true) {
    const k = 100;
}
console.log (k); // ReferenceError

Module(模块化)

ES5
按照顺序Require依赖 var myModule = require('./myModule');
ES6
允许在文件中import相应的依赖,或者export依赖 import myModule from './myModule';

Class declaration(声明类)

ES5

var Add = function (arg1, arg2) {
    this.arg1 = arg1;
    this.arg2 = arg2;
};
Add.prototype.calc = function () {
    return this.arg1 + '+' + this.arg2 + '=' + (this.arg1 + this.arg2);
};
var num = new Add (5, 8);
console.log (num.calc ()); // 5 + 8 = 13

ES6

class Add {
    constructor (arg1, arg2) {
        this.arg1 = arg1;
        this.arg2 = arg2;
    }
    calc () {
        return this.arg1 + '+' + this.arg2 + '=' + (this.arg1 + this.arg2);
    }
}
var num = new Add (5, 8);
console.log (num.calc ()); // 5 + 8 = 13

Manipulating objects in ES6 vs ES5

Merge object

ES5

var obj1 = { a: 1, b: 2 }
var obj2 = { a: 2, c: 3, d: 4}
var obj3 = Object.assign(obj1, obj2)

ES6

const obj1 = { a: 1, b: 2 }
const obj2 = { a: 2, c: 3, d: 4}
const obj3 = {...obj1, ...obj2}
Destructuring object

ES5

var obj1 = { a: 1, b: 2, c: 3, d: 4 }
var a = obj1.a
var b = obj1.b
var c = obj1.c
var d = obj1.d

ES6

const obj1 = { a: 1, b: 2, c: 3, d: 4 }
const {
  a,
  b,
  c,
  d
} = obj1

Promises vs Callbacks

ES5

function isGreater (a, b, cb) {
  
  var greater = false
  if(a > b) {
    greater = true
  }
  cb(greater)
}
isGreater(1, 2, function (result) {
  if(result) {
    console.log('greater');
  } else {
    console.log('smaller')
  }
})

ES6

const isGreater = (a, b) => {
 return new Promise ((resolve, reject) => {
  if(a > b) {
   resolve(true)
  } else {
   reject(false)
  }
 })
}
isGreater(1, 2)
 .then(result => {
    console.log('greater')
 })
 .catch(result => {
    console.log('smaller')
 })

The ES6 promises are better than callback because it allows us to distinguish easily between a success and error, so we don’t have to check it again in our callback function.

后续有新的知识点,会持续更新

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容