es8 --- 新特性

ES8還沒有發佈(2017年1月),下面是它已經完成起草的一些特性:javascript

Object.values()

不使用ES8

使用Object.keys()遍歷對象的屬性值,須要經過屬性名key去獲取屬性值:java

 
                                                    
let obj = {a: 1, b: 2, c: 3};
 
Object.keys(obj).forEach((key) =>
{
    console.log(obj[key]); // 輸出1, 2, 3
});
 
 

使用ES8

使用Object.values()遍歷對象的屬性值,無需使用使用屬性名:node

 
                                                    
let obj = {a: 1, b: 2, c: 3}
Object.values(obj).forEach(value =>
{
    console.log(value); // 輸出1, 2, 3
});
 
 

Object.entries()

不使用ES8

使用Object.keys()遍歷對象的屬性名和屬性值:ios

 
                                                    
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()遍歷對象的屬性名和屬性值:axios

 
 
                                                    
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()能夠在字符串前面填充指定的字符串:async

 
                                                    
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')
 
 

輸出以下:fetch

 
                                                    
0.00 0.00
10,000.00 10,000.00
250,000.00 250,000.00
 
 

使用ES8

使用padEnd()能夠在字符串後面填充指定的字符串:ui

 
                                                    
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個理由》

相關文章
相關標籤/搜索