ES8基本特性整理

es8特性

tip: es8标准已于2017年6月发布

Object.values()

  • 遍历对象属性值
let obj = {a: 1, b: 2, c: 3}
//    - 使用Object.keys()获取
Object.keys(obj).forEach((key) => {
  console.log(obj[key])
})
//    - 使用for/of 获取
for (let key of Object.keys(obj)) {
  console.log(obj[key])
}
//    - 使用es8
Object.values(obj).forEach(value => { console.log(value) })
console.log(Object.values(obj))  // 输出结果为value组成的数组 [1,2,3]

tip: 虽然使用for/in也可以,但是当它碰到迭代枚举属性时,会破坏像prototype和tostring的属性得到意想不到的值。

Object.entries()

  • 遍历对象的属性名和属性值
let obj = {a: 1, b: 2, c: 3}
// 使用Object.keys()遍历
Object.keys(obj).forEach((key) => {
  console.log(key + ':' + obj[key])
})
// 使用for/of遍历
for (let key of Object.keys(obj)) {
  console.log(key + ':' + obj[key])
}
// 使用Object.entries()
Object.entries(obj).forEach(([key, value]) => {
  console.log(key + ':' + value) 
})
console.log(Object.entries(obj)) // [['a',1],['b',2],['c',3]]

tip: Object.entries(x)强制x转换为对象,并以数组的方式返回其可枚举的自定义字符串

字符串填充

  • padStart()
    在字符串开始部位填充空格,返回一个给出长度的字符串–常用于格式化字符串
console.log('abc'.padStart(10))
console.log('abcdef'.padStart(10))
//        abc
//     abcdef
console.log('123'.padStart(10,'*')) // *******123
  • padEnd()
    在字符串尾端填充空格,返回一个给出长度的字符串
console.log('0.00'.padEnd(20) + '0.00')
console.log('10,000.00'.padEnd(20) + '10,000.00')
// 0.00                0.00
// 10,000.00           10,000.00
console.log('158'.padEnd(11,'*'))  // 158********
console.log('158'.padEnd(11,'*').length)  // 11

Object.getOwnPropertyDescriptors()

  • Object.getOwnPropertyDescriptors返回对象obj所有自身属性描述。
    这是一个多参数版本的Object.getOwnPropertyDescriptors(obj,propName)将会返回obj中propName属性的一个单独描述。
  • 在ES5中,ECMAScript中没有单个方法来简化两个对象之间的正确拷贝。开发者要使用Object.assign()来拷贝对象, Object.assign()分配属性只有copy和定义新的属性。当我们使用更加复杂对象和类原型,这可能会出问题。
  • Object.getOwnPropertyDescriptors允许创建真实的对象浅副本并创建子类,它通过给开发者描述符来做到这一点.在Object.create(prototype, object)放入描述符后,返回一个真正的浅拷贝。
Object.create(
  Object.getPrototypeOf(obj),
  Object.getOwnPropertyDescriptors(obj)
)

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

  • 避免不必要的报错
function(a,b,c){
    console.log(a)
}
// es8
function(a,b,c,){
    console.log(a)
}

async/await – 后续整理

  • 使用promise写异步代码
function fetchData(url) {  
  return fetch(url)  
    .then(request => request.text())  
    .then(text => {  
      return JSON.parse(text);  
     })  
    .catch(err => {  
      console.log(`Error: ${err.stack}`);  
    });  
}
  • 使用async/await
async function fetchData(url) {  
  try {  
   let request = await fetch(url);  
   let text = await request.text();  
   return JSON.parse(text);  
  }  
  catch (err) {  
    console.log(`Error: ${err.stack}`);  
  }  
}

tip: Async/Await是写异步代码的新方式,以前的方法有回调函数和Promise。相比于Promise,它更加简洁,并且处理错误、条件语句、中间值都更加方便,因此有望替代Promise,成为新一代的一步代码编写方式。

你可能感兴趣的:(JS)