中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

聊聊ES7和ES8特性

發布時間:2020-07-07 23:42:34 來源:網絡 閱讀:236 作者:Fundebug 欄目:web開發

譯者按: 轉眼ES6發布2年了,×××解一下ES7ES8特性了!

  • 原文: ES7 and ES8 Features

  • 譯者: Fundebug

為了保證可讀性,本文采用意譯而非直譯,并且對源代碼進行了大量修改。另外,本文版權歸原作者所有,翻譯僅用于學習。

我曾寫過一篇關于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.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/

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

葵青区| 乐山市| 青神县| 北流市| 昭平县| 绥中县| 健康| 嘉义县| 荥经县| 清水县| 苍溪县| 泰宁县| 栾城县| 马边| 三门峡市| 格尔木市| 永州市| 永仁县| 阳高县| 深圳市| 玛沁县| 延川县| 平谷区| 横峰县| 韶关市| 无为县| 宜春市| 沂水县| 临安市| 惠来县| 威海市| 东辽县| 河西区| 定边县| 沅江市| 邵东县| 万宁市| 金寨县| 特克斯县| 南华县| 邹平县|