一、概述數組
Iterator 的做用有三個:一是爲各類數據結構,提供一個統一的、簡便的訪問接口;二是使得數據結構的成員可以按某種次序排列;三是 ES6 創造了一種新的遍歷命令for...of
循環,Iterator 接口主要供for...of循環
。數據結構
二、Iterator 接口函數
ES6 的有些數據結構原生具有 Iterator 接口(好比數組),即不用任何處理,就能夠被for...of
循環遍歷。緣由在於,這些數據結構原生部署了Symbol.iterator
屬性,另一些數據結構沒有(好比對象)。凡是部署了Symbol.iterator
屬性的數據結構,就稱爲部署了遍歷器接口。調用這個接口,就會返回一個遍歷器對象。spa
原生具有 Iterator 接口的數據結構以下。code
三、只要某個數據結構部署了 Iterator 接口,就能夠對它使用擴展運算符,將其轉爲數組。對象
let arr = [...iterable];
四、for...ofblog
JavaScript 原有的for...in
循環,只能得到對象的鍵名,不能直接獲取鍵值。ES6 提供for...of
循環,容許遍歷得到鍵值。索引
var arr = ['a', 'b', 'c', 'd']; for (let a in arr) { console.log(a); // 0 1 2 3
} for (let a of arr) { console.log(a); // a b c d
}
Set 結構和 Map 結構=遍歷的順序是按照各個成員被添加進數據結構的順序。其次,Set 結構遍歷時,返回的是一個值,而 Map 結構遍歷時,返回的是一個數組,該數組的兩個成員分別爲當前 Map 成員的鍵名和鍵值。
entries()
返回一個遍歷器對象,用來遍歷[鍵名, 鍵值]
組成的數組。對於數組,鍵名就是索引值;對於 Set,鍵名與鍵值相同。Map 結構的 Iterator 接口,默認就是調用entries
方法。