介绍
迭代器(iterator)是一种接口,为各种不同的数据结构提供统一的访问机制。
任何数据结构只要部署iterator借口,就可以完成遍历操作。
1.ES6创造了一种新的遍历命令for...of循环,ierator接口主要供for...of消费
2.原生具备iterator借口的数据(可用for of遍历)
3.工作原理
创建一个指针对象,指向当前数据结构的起始位置
第一次调用对象的next方法,指针自动指向数据结构的第一个成员
接下来不断调用next方法,指针一直往后移动,直到指向最后一个成员
注意:
需要自定义遍历数据的时候,要想到迭代器。
创建
迭代器的本身是一个对象,这个对象有 next( ) 方法返回结果对象,这个结果对象有下一个返回值 value、迭代完成布尔值 done,模拟创建一个简单迭代器如下:
function createIterator(iterms) { let i = 0 return { next() { let done = (i >= iterms.length) let value = !done ? iterms[i++] : undefined return { done, value } } } }
标签:遍历,迭代,iterator,next,done,数据结构 From: https://www.cnblogs.com/0722tian/p/17108074.html