聊聊ES7与ES8特性

简介: 我曾写过一篇关于ES6博客《10个最佳ES6特性》,这次我打算聊聊ES7和 ES8特性。ES7只有2个特性:• includes()• 指数操作符ES8尚未发布(2017年1月),下面是它已经完成起草的一些特性:• Object.values()• Object.entries()• padStart()• padEnd()• Object.getOwnPropertyDescriptors()• 函数参数列表结尾允许逗号• Async/Await



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

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.keys(obj).forEach((key) =>
{
console.log(obj[key]); // 输出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)
})
目录
相关文章
|
Java Maven 微服务
springboot项目开启远程调试-jar包
springboot项目开启远程调试-jar包
499 0
|
4月前
|
机器学习/深度学习 算法
基于自抗扰控制ADRC的永磁同步电机仿真模型(Simulink仿真实现)
基于自抗扰控制ADRC的永磁同步电机仿真模型(Simulink仿真实现)
335 1
|
数据采集 存储 分布式计算
一篇文章搞懂数据仓库:数据治理(目的、方法、流程)
一篇文章搞懂数据仓库:数据治理(目的、方法、流程)
27924 2
一篇文章搞懂数据仓库:数据治理(目的、方法、流程)
|
存储 监控 Java
JVM进阶调优系列(8)如何手把手,逐行教她看懂GC日志?| IT男的专属浪漫
本文介绍了如何通过JVM参数打印GC日志,并通过示例代码展示了频繁YGC和FGC的场景。文章首先讲解了常见的GC日志参数,如`-XX:+PrintGCDetails`、`-XX:+PrintGCDateStamps`等,然后通过具体的JVM参数和代码示例,模拟了不同内存分配情况下的GC行为。最后,详细解析了GC日志的内容,帮助读者理解GC的执行过程和GC处理机制。
|
监控 架构师 Java
JVM进阶调优系列(6)一文详解JVM参数与大厂实战调优模板推荐
本文详述了JVM参数的分类及使用方法,包括标准参数、非标准参数和不稳定参数的定义及其应用场景。特别介绍了JVM调优中的关键参数,如堆内存、垃圾回收器和GC日志等配置,并提供了大厂生产环境中常用的调优模板,帮助开发者优化Java应用程序的性能。
ly~
|
传感器 存储 供应链
大数据在供应链管理中的具体应用案例
以下是大数据在供应链管理中的具体应用案例:沃尔玛通过整合内外部数据进行需求预测,提前调配应急物资;亚马逊利用大数据优化库存管理,提高周转率并降低成本;DHL通过传感器收集数据优化物流路线,提升运输效率。大数据的优势在于提高需求预测准确性、优化库存管理、提升物流效率、增强供应商管理和提高供应链可视性,从而实现全方位的供应链优化。
ly~
3154 2
|
SQL 机器学习/深度学习 自然语言处理
Text-to-SQL技术演进 - 阿里云OpenSearch-SQL在BIRD榜单夺冠方法剖析
本文介绍了Text-to-SQL的技术演进,并对OpenSearch-SQL方法进行剖析。
1851 8
|
数据安全/隐私保护
kali下设置root权限(包含很多技巧)
kali下设置root权限(包含很多技巧)
|
算法 Linux 调度
嵌入式linux面试题目总结
嵌入式linux面试题目总结
425 0