Iterators and Generators
Many programming languages have shifted from iterating over data with for
loops, which require initializing variables to track position in a collection, to using iterator objects that programmatically return the next item in a collection. Iterators make working with collections of data easier, and ECMAScript 6 adds iterators to JavaScript. When coupled with new array methods and new types of collections (such as sets and maps), iterators are key for efficient data processing, and you will find them in many parts of the language. There’s a new for-of
loop that works with iterators, the spread (...
) operator uses iterators, and iterators even make asynchronous programming easier.
This chapter covers the many uses of iterators, but first, it’s important to understand the history behind why iterators were added to JavaScript.