Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Understanding Iterators & Iterables in JavaScript
Search
Jenn Creighton
May 17, 2019
Programming
150
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Understanding Iterators & Iterables in JavaScript
Jenn Creighton
May 17, 2019
More Decks by Jenn Creighton
See All by Jenn Creighton
Everything I Know About React I Learned From Twitter
jenncreighton
0
1.1k
React 16, the future & you (December 4, 2018)
jenncreighton
1
190
The how and why of flexible React components
jenncreighton
7
4.4k
The How and Why of Flexible React Components
jenncreighton
0
200
React 16, the future & you
jenncreighton
0
210
Other Decks in Programming
See All in Programming
脅威をエンジニアリングの糧にして――現場編 / Turning Threats into Engineering Fuel — Field Edition
nrslib
0
290
JavaDoc 再入門
nagise
1
370
net-httpのHTTP/2対応について
naruse
0
500
その問い、本当に正しいですか?AI時代のエンジニアに必要な哲学と認知科学 / ai-philosophy-cognitive-science
minodriven
11
5.9k
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
140
Hunting Vulnerabilities in Symfony with LLMs
vinceamstoutz
0
550
ユニットテストの先へ:テスト技法で要求・仕様を整理するJava開発実践 / Beyond_Unit_Testing_Practical_Java_Development_Techniques_for_Organizing_Requirements_and_Specifications
shimashima35
0
410
Go1.27で導入されるジェネリクスメソッドでできること
mackee
0
140
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
Spring Security 実践 ─ GraphQL APIで実務に役立つ 認証・認可 を学ぶ
wagyu
0
250
Semantic Version 単位で戦略を柔軟に変えて、パッケージアップデートを自動化する
daitasu
1
260
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
13k
Featured
See All Featured
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
10
1.2k
Speed Design
sergeychernyshev
33
1.9k
Bridging the Design Gap: How Collaborative Modelling removes blockers to flow between stakeholders and teams @FastFlow conf
baasie
0
590
The Organizational Zoo: Understanding Human Behavior Agility Through Metaphoric Constructive Conversations (based on the works of Arthur Shelley, Ph.D)
kimpetersen
PRO
0
360
Abbi's Birthday
coloredviolet
2
8.1k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Making the Leap to Tech Lead
cromwellryan
135
9.9k
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.5k
Mind Mapping
helmedeiros
PRO
1
250
New Earth Scene 8
popppiees
3
2.3k
Designing Powerful Visuals for Engaging Learning
tmiket
1
420
Transcript
Understanding Iterators & Iterables in JavaScript
Hi! I’m Jenn! Senior Frontend Engineer @gurlcode @ Rent the
Runway
! @gurlcode
... Spread Operator @gurlcode
[ ] @gurlcode
[ 1, 2, 3 ] @gurlcode
...[ 1, 2, 3 ] @gurlcode
...[ 1, 2, 3 ] // 1, 2, 3 @gurlcode
..."abc" // "a", "b", "c" @gurlcode
function* generator( ) { yield 1; yield 2; yield 3;
} …generator( ) // 1, 2, 3 @gurlcode
@gurlcode
Generators 101 @gurlcode
function* count() { yield 1; yield; yield 3; } @gurlcode
function* count() { yield 1; yield; yield 3; } var
generator = count(); Generator {}; @gurlcode
function* count() { yield 1; yield; yield 3; } var
generator = count(); generator.next(); { value: 1, done: false } Generator {};
function* count() { yield 1; yield; yield 3; } var
generator = count(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: undefined, done: false } { value: 3, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* count() { yield 1; yield; yield 3; } var
generator = count(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: undefined, done: false } { value: 3, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* count() { yield 1; yield; yield 3; } var
generator = count(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: undefined, done: false } { value: 3, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* add() { const num = yield; yield 2 +
num; yield 4 + num; } var generator = add(); generator.next(); generator.next(2); generator.next(); generator.next(); { value: undefined, done: false } { value: 4, done: false } { value: 6, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* add() { const num = yield; yield 2 +
num; yield 4 + num; } var generator = add(); generator.next(); generator.next(2); generator.next(); generator.next(); { value: undefined, done: false } { value: 4, done: false } { value: 6, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* add() { const num = yield; yield 2 +
num; yield 4 + num; } var generator = add(); generator.next(); generator.next(2); generator.next(); generator.next(); { value: undefined, done: false } { value: 4, done: false } { value: 6, done: false } { value: undefined, done: true } Generator {}; @gurlcode
function* add() { const num = yield; yield 2 +
num; yield 4 + num; } var generator = add(); generator.next(); generator.next(2); generator.next(); generator.next(); { value: undefined, done: false } { value: 4, done: false } { value: 6, done: false } { value: undefined, done: true } Generator {}; @gurlcode
yield* @gurlcode
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } var generator = outer(); Generator {}; @gurlcode
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } var generator = outer(); Generator {}; @gurlcode
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } var generator = outer(); Generator {}; @gurlcode
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } var generator = outer(); Generator {}; @gurlcode
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } generator.next(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: “a”, done: false } { value: “b”, done: false } { value: 2, done: false } { value: undefined, done: true }
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } generator.next(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: “a”, done: false } { value: “b”, done: false } { value: 2, done: false } { value: undefined, done: true }
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } generator.next(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: “a”, done: false } { value: “b”, done: false } { value: 2, done: false } { value: undefined, done: true }
function* outer() { yield 1; yield* inner(); yield 2; }
function* inner() { yield “a”; yield “b”; } generator.next(); generator.next(); generator.next(); generator.next(); generator.next(); { value: 1, done: false } { value: “a”, done: false } { value: “b”, done: false } { value: 2, done: false } { value: undefined, done: true }
function* generator( ) { yield 1; yield 2; yield 3;
} ...generator() // 1, 2, 3 @gurlcode
Arrays Strings Maps Sets Generators @gurlcode
Iterable a data structure that provides an interface for iteration
@gurlcode
Iterable Protocol
Symbol.iterator @gurlcode
Symbol( "key" ) @gurlcode
Array.prototype[ Symbol.iterator ] @gurlcode
String.prototype[ Symbol.iterator ] @gurlcode
function* generator( ) { } generator[ Symbol.iterator ] @gurlcode
Iterator any object which implements the Iterator protocol @gurlcode
Iterator Protocol @gurlcode
function fakeIterator( ) { return { next: function( ) {
} }; } @gurlcode
function fakeIterator( ) { return { next: function( ) {
// return object // with a value // & a done key } }; } @gurlcode
const iterator = fakeIterator( ); const { value, done }
= iterator.next( ); @gurlcode
const iterator = fakeIterator( ); const { value, done }
= iterator.next( ); @gurlcode
Let’s create our own! @gurlcode
None
Async Iterator @gurlcode
Symbol.asyncIterator @gurlcode
... Spread Operator @gurlcode
{ } @gurlcode
...{ } @gurlcode
Thank you! @gurlcode