为了账号安全,请及时绑定邮箱和手机立即绑定

聊聊ES7和ES8特性

标签:
AngularJS


译者按: 转眼ES6发布2年了,×××解一下ES7与ES8特性了!

原文: ES7 and ES8 Features

译者: Fundebug

为了保证可读性,本文采用意译而非直译,并且对源代码进行了大量修改。另外,本文版权归原作者所有,翻译仅用于学习。

我曾写过一篇关于ES6博客《10个最佳ES6特性》,这次我打算聊聊ES7和ES8特性。

ES7只有2个特性:

includes()

指数操作符

ES8尚未发布(2017年1月),下面是它已经完成起草的一些特性:

Object.values()

Object.entries()

padStart()

padEnd()

Object.getOwnPropertyDescriptors()

函数参数列表结尾允许逗号

Async/Await

Array.prototype.includes()

不使用ES7

使用indexOf()验证数组中是否存在某个元素,这时需要根据返回值是否为-1来判断:

let arr = ['react', 'angular', 'vue'];

if (arr.indexOf('react') !== -1)

{

    console.log('React存在');

}

使用ES7

使用includes()验证数组中是否存在某个元素,这样更加直观简单:

let arr = ['react', 'angular', 'vue'];

if (arr.includes('react'))

{

    console.log('React存在');

}

指数操作符

不使用ES7

使用自定义的递归函数calculateExponent或者Math.pow()进行指数运算:

function calculateExponent(base, exponent)

{

    if (exponent === 1)

    {

        return base;

    }

    else

    {

        return base * calculateExponent(base, exponent - 1);

    }

}

console.log(calculateExponent(7, 3)); // 输出343

console.log(Math.pow(7, 3)); // 输出343

使用ES7

使用指数运算符**,就像+、-等操作符一样:

console.log(7**3);

Object.values()

不使用ES8

使用Object.keys()遍历对象的属性值,需要通过属性名key去获取属性值:

let obj = {a: 1, b: 2, c: 3};

Object.keys(obj).forEach((key) =>

{

    console.log(obj[key]); // 输出1, 2, 3

});

使用ES8

使用Object.values()遍历对象的属性值,无需使用使用属性名:

let obj = {a: 1, b: 2, c: 3}

Object.values(obj).forEach(value =>

{

    console.log(value); // 输出1, 2, 3

});

Object.entries()

不使用ES8

使用Object.keys()遍历对象的属性名和属性值:

let obj = {a: 1, b: 2, c: 3};

Object.keys(obj).forEach((key) =>

{

    console.log(key + ": " + obj[key]); // 输出a: 1, b: 2, c: 3

})

使用ES8

使用Object.entries()遍历对象的属性名和属性值:

let obj = {a: 1, b: 2, c: 3};

Object.entries(obj).forEach(([key, value]) =>

{

    console.log(key + ": " + value); // 输出a: 1, b: 2, c: 3

})

padStart()

不使用ES8

console.log('0.00')             

console.log('10,000.00')    

console.log('250,000.00')  

输出结果如下:

0.00

10,000.00

250,000.00

使用ES8

使用padStart()可以在字符串前面填充指定的字符串:

console.log('0.00'.padStart(20))            

console.log('10,000.00'.padStart(20))    

console.log('250,000.00'.padStart(20))    

输出结果如下:

                0.00

           10,000.00

          250,000.00

padEnd()

不使用ES8

console.log('0.00 ' + '0.00' )          

console.log('10,000.00 ' + '10,000.00' )    

console.log('250,000.00 ' + '250,000.00')  

输出如下:

0.00 0.00

10,000.00 10,000.00

250,000.00 250,000.00

使用ES8

使用padEnd()可以在字符串后面填充指定的字符串:

console.log('0.00'.padEnd(20) + '0.00' )            

console.log('10,000.00'.padEnd(20) + '10,000.00' )    

console.log('250,000.00'.padEnd(20) + '250,000.00')  

输出如下:

0.00                0.00

10,000.00           10,000.00

250,000.00          250,000.00

Object.getOwnPropertyDescriptors()

azatsBooks对象的定义如下:

let azatsBooks = {

    books: ['React Quickly'],

    get latest()

    {

        let numberOfBooks = this.books.length;

        if (numberOfBooks == 0) return undefined;

        return this.books[numberOfBooks - 1];

    }

};

不使用ES8

使用Object.getOwnPropertyDescriptor()获取单个属性的属性描述符。

获取azatsBooks对象的books属性的属性描述符:

console.log(Object.getOwnPropertyDescriptor(azatsBooks, 'books'));

/** 输出books属性的属性描述

[object Object] {

  configurable: true,

  enumerable: true,

  value: ["React Quickly"],

  writable: true

}

**/

获取azatsBooks对象的lastest方法的属性描述符:

console.log(Object.getOwnPropertyDescriptor(azatsBooks, 'latest'));

/** 输出lastest方法的属性描述

[object Object] {

  configurable: true,

  enumerable: true,

  get: function get latest() {

    let numberOfBooks = this.books.length

    if (numberOfBooks == 0) return undefined

    return this.books[numberOfBooks - 1]

  },

  set: undefined

}

**/

使用ES8

Object.getOwnPropertyDescriptors()相当于Object.getOwnPropertyDescriptor()的复数形式,可以获取对象的所有自身属性的描述符:

console.log(Object.getOwnPropertyDescriptors(azatsBooks))

/** 输出azatsBooks对象所有自身属性的属性描述

[object Object] {

  books: [object Object] {

    configurable: true,

    enumerable: true,

    value: ["React Quickly"],

    writable: true

  },

  latest: [object Object] {

    configurable: true,

    enumerable: true,

    get: function get latest() {

      let numberOfBooks = this.books.length

      if (numberOfBooks == 0) return undefined

      return this.books[numberOfBooks - 1]

    },

    set: undefined

  }

}

**/

函数参数列表结尾允许逗号

不使用ES8

var f = function(a,

  b,

  c,

  d // d之后不能带逗号

   ) { 

  console.log(d)

}

使用ES8

var f = function(a,

  b,

  c,

  d, // d之后允许带逗号

) { 

  console.log(d)

}

允许逗号之后,可以避免一些不必要的报错。(如果你希望实时监控JavaScript应用的错误,欢迎免费使用Fundebug)

Async/Await

使用Promise

使用Promise写异步代码,会比较麻烦:

axios.get(`/q?query=${query}`)

    .then(response => response.data)

    .then(data =>

    {

        this.props.processfetchedData(data);

    })

    .catch(error => console.log(error));

使用Async/Await

Async/Await使得异步代码看起来像同步代码,这正是它的魔力所在:

async fetchData(query) =>

{

    try

    {

        const response = await axios.get(`/q?query=${query}`);

        const data = response.data;

        return data;

    }

    catch (error)

    {

        console.log(error)

    }

}

fetchData(query).then(data =>

{

    this.props.processfetchedData(data)

})

Async/Await是写异步代码的新方式,以前的方法有回调函数和Promise。相比于Promise,它更加简洁,并且处理错误、条件语句、中间值都更加方便,因此有望替代Promise,成为新一代的一步代码编写方式。对细节感兴趣的话,可以查看[Fundebug]()翻译的《Async/Await替代Promise的6个理由》。

关于Fundebug:

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了7亿+错误事件,得到了Google、360、金山软件、百姓网等众多知名用户的认可。欢迎免费试用!

聊聊ES7和ES8特性

版权声明

转载时请注明作者Fundebug以及本文地址:

https://blog.fundebug.com/2017/08/28/es7-and-es8/

©著作权归作者所有:来自51CTO博客作者Fundebug的原创作品,如需转载,请注明出处,否则将追究法律责任


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消