以前JS原生的集合类型数据结构,只有Array(数组)和Object(对象);
而ES6中,又新增了Map和Set。四种数据结构各自有着自己特别的内部实现,但我们仍期待以同样的一套规则去遍历它们,所以ES6在推出新数据结构的同时也推出了一套统一的接口机制——迭代器(Iterator)。
ES6约定,任何数据结构只要具备Symbol.iterator属性(这个属性就是Iterator的具体实现,它本质上是当前数据结构默认的迭代器生成函数),就可以被遍历——准确地说,是被for…of…循环和迭代器的next方法遍历。 事实上,for…of…的背后正是对next方法的反复调用。
// 定义一个迭代器对象
const iterator = {
next() {
// 返回当前迭代的元素和是否完成迭代的标志
return { value: 1, done: false };
}
};
// 使用迭代器对象进行迭代
let result = iterator.next();
while (!result.done) {
console.log(result.value);
result = iterator.next();
}