<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Jonas Mendes</title>
    <description>The latest articles on DEV Community by Jonas Mendes (@nipher).</description>
    <link>https://dev.to/nipher</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F46539%2F14298692-1e9b-4e93-8e0c-7243a04ad030.jpeg</url>
      <title>DEV Community: Jonas Mendes</title>
      <link>https://dev.to/nipher</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/nipher"/>
    <language>en</language>
    <item>
      <title>The Importance of Iteration Protocols</title>
      <dc:creator>Jonas Mendes</dc:creator>
      <pubDate>Sat, 09 Dec 2017 18:08:34 +0000</pubDate>
      <link>https://dev.to/nipher/the-importance-of-iteration-protocols-33g</link>
      <guid>https://dev.to/nipher/the-importance-of-iteration-protocols-33g</guid>
      <description>&lt;p&gt;Hey everyone, recently I caught myself talking to a great friend of mine (&lt;a href="http://maksimivanov.com/"&gt;Maksim Ivanov&lt;/a&gt;, he writes some really useful articles) about iteration protocols in javascript, during the discussion we were very happy with the language improvements that these protocols bring and we also noticed even more things about it, because of this discussion, I decided to write this article.&lt;/p&gt;

&lt;p&gt;Let's get started then, first, let me list the topics that I want to talk about:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Iteration Protocols?&lt;/li&gt;
&lt;li&gt;Its true value&lt;/li&gt;
&lt;li&gt;for..of&lt;/li&gt;
&lt;li&gt;&lt;a href="https://nipher.io/the-importance-of-iteration-protocols/#creating-a-custom-iterator"&gt;Creating a custom iterator&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://nipher.io/the-importance-of-iteration-protocols/#built-in-iterables"&gt;Built-in iterables&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://nipher.io/the-importance-of-iteration-protocols/#iterating-over-objects"&gt;Iterating over objects&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://nipher.io/the-importance-of-iteration-protocols/#other-languages"&gt;Other languages&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://nipher.io/the-importance-of-iteration-protocols/#conclusion"&gt;Conclusion&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2 id="iteration-protocols"&gt;Iteration Protocols?&lt;/h2&gt;

&lt;p&gt;Ok, if you don't even know what I'm talking about, I'll explain it real quick and show an example.&lt;/p&gt;

&lt;p&gt;Among the iteration protocols we have the Iterable and the Iterator.&lt;/p&gt;

&lt;p&gt;Let's check them out separately:&lt;/p&gt;

&lt;h4&gt;
  
  
  Iterable
&lt;/h4&gt;

&lt;p&gt;This protocol simply defines a way to specify the iteration behavior of an object.&lt;br&gt;&lt;br&gt;
So for example, we have a string object &lt;code&gt;'Hello World'&lt;/code&gt;, the object itself will tell how its iteration should be like.&lt;/p&gt;

&lt;p&gt;How's that? &lt;/p&gt;

&lt;p&gt;Well, let's see a code snippet and explain its code, I believe it'll be easier to understand.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;message&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Hello World&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;Symbol&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;iterator&lt;/span&gt;&lt;span class="p"&gt;])&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; ƒ [Symbol.iterator]() { [native code] }&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;Symbol&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;iterator&lt;/span&gt;&lt;span class="p"&gt;]())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; StringIterator {}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;So, wtf?&lt;/p&gt;

&lt;p&gt;Let's go through it:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;A string is created and assigned to the &lt;code&gt;message&lt;/code&gt; constant&lt;/li&gt;
&lt;li&gt;We use &lt;code&gt;message[Symbol.iterator]&lt;/code&gt; to access a function (which will return an iterator)&lt;/li&gt;
&lt;li&gt;We call the function, which returns a &lt;code&gt;StringIterator&lt;/code&gt; (which implements the Iterator Protocol)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;That's the iterable protocol, having the &lt;code&gt;[Symbol.iterator]&lt;/code&gt; defined, so anyone can call it and get its iterator, which can be used to get the values to be iterated.&lt;/p&gt;

&lt;p&gt;As you might have noticed, we didn't need to implement/define it, the string object already has a &lt;code&gt;[Symbol.iterator]&lt;/code&gt; defined, it comes from its prototype (&lt;code&gt;String.prototype[Symbol.iterator]&lt;/code&gt;), that's not the case for all types of objects, we'll talk more about it on the topic "Built-in iterables".&lt;/p&gt;

&lt;h4&gt;
  
  
  Iterator
&lt;/h4&gt;

&lt;p&gt;This protocol is basically an interface for getting sequencial values.&lt;/p&gt;

&lt;p&gt;If you think about it for a bit, that's what an iteration is about, getting values sequencially from something. And you'll also realize how many different types of objects we usually want to iterate over:&lt;br&gt;&lt;br&gt;
Arrays, Strings, Map, Set, DOM data structures, Streams, Objects...&lt;/p&gt;

&lt;p&gt;Now, in case we want to get sequencial values from one of these guys, we could use the iterator protocol to do so.&lt;/p&gt;

&lt;p&gt;An iterator needs to implement this interface:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
    &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="na"&gt;value&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;Anything&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="na"&gt;done&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nb"&gt;Boolean&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt;
  &lt;span class="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Let's use a string again, so we can see these two protocols working together:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;message&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Hello&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;messageIterator&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;Symbol&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;iterator&lt;/span&gt;&lt;span class="p"&gt;]()&lt;/span&gt; &lt;span class="c1"&gt;// &amp;gt; StringIterator {}&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: 'H', done: false }&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: 'e', done: false }&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: 'l', done: false }&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: 'l', done: false }&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: 'o', done: false }&lt;/span&gt;
&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;messageIterator&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;())&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; { value: undefined, done: true }&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Well, I guess it's starting to make some sense, right?&lt;/p&gt;

&lt;p&gt;Let's go through it real quick&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;We define the string and get an instance of its iterator from it&lt;/li&gt;
&lt;li&gt;We start calling &lt;code&gt;next()&lt;/code&gt; from the iterator instance (the interface that I mentioned)&lt;/li&gt;
&lt;li&gt;Each value returned by &lt;code&gt;next()&lt;/code&gt; is a letter from the string&lt;/li&gt;
&lt;li&gt;It returns letters in a left -&amp;gt; right order from the string&lt;/li&gt;
&lt;li&gt;When there are no letters left, we get &lt;code&gt;undefined&lt;/code&gt; as a value and &lt;code&gt;true&lt;/code&gt; as done (which means there're no more values)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;If you think about it, it's a very simple interface and yet it brings a lot of value to the javascript language.&lt;/p&gt;

&lt;h2 id="its-true-value"&gt;Its true value&lt;/h2&gt;

&lt;p&gt;As I glimpsed before, we have a lot of cases which we would like to iterate over some kind of structure/object.&lt;/p&gt;

&lt;p&gt;We didn't really have a well defined interface for doing it, resulting in different ways to iterate over stuff.&lt;/p&gt;

&lt;p&gt;A lot of libraries solved this problem for us, &lt;code&gt;lodash&lt;/code&gt; for example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="nx"&gt;_&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;forEach&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Hello&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;value&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'H' &lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'e'&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'l'&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'l'&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'o'&lt;/span&gt;

&lt;span class="nx"&gt;_&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;forEach&lt;/span&gt;&lt;span class="p"&gt;([&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="nx"&gt;value&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 1 &lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 2&lt;/span&gt;

&lt;span class="nx"&gt;_&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;forEach&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;a&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;b&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt; &lt;span class="p"&gt;},&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'a' &lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 'b'&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;As you can see above, one single function &lt;code&gt;.forEach(...)&lt;/code&gt; which works with any kind of object (String, Array, Object).&lt;/p&gt;

&lt;p&gt;But it was about time, that the language itself would improve that, so we wouldn't need a library to execute such a simple thing in a programming language.&lt;/p&gt;

&lt;p&gt;Don't get me wrong, I love lodash and such, and they're still super useful and relevant today, they themselves can use and benefit from the iteration interfaces, and they do, imagine how simpler it is to implement their &lt;code&gt;_.forEach&lt;/code&gt; method now than it was before.&lt;/p&gt;

&lt;p&gt;That's the real value, the combination of simplicity, consistency and well defined patterns.&lt;/p&gt;

&lt;h2 id="for-of"&gt;for..of&lt;/h2&gt;

&lt;p&gt;So, how can we use these protocols in a generic way?&lt;/p&gt;

&lt;p&gt;Now, we have &lt;code&gt;for (let value of &amp;lt;iterable&amp;gt;) { ... }&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;As you can see, it's different than the &lt;code&gt;for&lt;/code&gt; we're used to.&lt;/p&gt;

&lt;p&gt;Let's check some &lt;code&gt;for..of&lt;/code&gt; examples:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;message&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;Hello&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;

&lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;letter&lt;/span&gt; &lt;span class="k"&gt;of&lt;/span&gt; &lt;span class="nx"&gt;message&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;letter&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// &amp;gt; H&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; e&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; l&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; l&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; o&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;list&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;3&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;4&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;5&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;

&lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;i&lt;/span&gt; &lt;span class="k"&gt;of&lt;/span&gt; &lt;span class="nx"&gt;list&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;i&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// &amp;gt; 1&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 2&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 3&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 4&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 5&lt;/span&gt;

&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;person&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="k"&gt;new&lt;/span&gt; &lt;span class="nb"&gt;Map&lt;/span&gt;&lt;span class="p"&gt;([[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;name&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;jonas&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="s1"&gt;age&lt;/span&gt;&lt;span class="dl"&gt;'&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;23&lt;/span&gt;&lt;span class="p"&gt;]])&lt;/span&gt;

&lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;person&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; Map { name → "Jonas", age → 23 }&lt;/span&gt;

&lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="k"&gt;of&lt;/span&gt; &lt;span class="nx"&gt;person&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;:`&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// &amp;gt; name: Jonas&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; age: 23&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;How about &lt;code&gt;for..in&lt;/code&gt;?&lt;/p&gt;

&lt;p&gt;It's still different.&lt;/p&gt;

&lt;p&gt;The &lt;code&gt;for..in&lt;/code&gt; iteration does not use iteration protocols, it iterates over enumerable properties of objects, unless the property's name is a &lt;code&gt;Symbol&lt;/code&gt; or defined via &lt;code&gt;Object.defineProperty&lt;/code&gt; setting &lt;code&gt;enumerable&lt;/code&gt; to &lt;code&gt;false&lt;/code&gt;.&lt;/p&gt;

&lt;p&gt;This also means it would also iterate over its prototype properties (if they fit the description above).&lt;/p&gt;

&lt;p&gt;You can avoid such thing by adding a conditional &lt;code&gt;if (obj.hasOwnProperty(prop)) { ... }&lt;/code&gt; inside your &lt;code&gt;for..in&lt;/code&gt; block, so it will execute the code only for properties of the actual instance.&lt;/p&gt;

&lt;p&gt;However, you can avoid &lt;code&gt;for..in&lt;/code&gt; if you wish, and use iteration protocols with &lt;code&gt;Object&lt;/code&gt; instances like you would use &lt;code&gt;for..in&lt;/code&gt; (without the necessity of the conditional though), make sure to use one of the static methods when using &lt;code&gt;for..of&lt;/code&gt; with &lt;code&gt;Object&lt;/code&gt; types, for example: &lt;code&gt;Object.entries&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;I'll show how it looks like on the topic "Iterating over objects".&lt;/p&gt;

&lt;h2 id="creating-a-custom-iterator"&gt;Creating a custom iterator&lt;/h2&gt;

&lt;p&gt;One interesting thing to point out, is that these protocols are not stricted to be implemented only in the javascript engines, it's also possible to create a custom one.&lt;/p&gt;

&lt;p&gt;Let's check an example?&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight javascript"&gt;&lt;code&gt;&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nx"&gt;rangeOf&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;n&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;i&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="nx"&gt;range&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

  &lt;span class="nx"&gt;range&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;Symbol&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;iterator&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="o"&gt;=&amp;gt;&lt;/span&gt; &lt;span class="p"&gt;({&lt;/span&gt;
    &lt;span class="nx"&gt;next&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
      &lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;done&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;i&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;=&lt;/span&gt; &lt;span class="nx"&gt;n&lt;/span&gt; &lt;span class="p"&gt;?&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;i&lt;/span&gt;&lt;span class="o"&gt;++&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kc"&gt;false&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="kc"&gt;undefined&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="kc"&gt;true&lt;/span&gt;&lt;span class="p"&gt;])&lt;/span&gt;
      &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nx"&gt;value&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;done&lt;/span&gt; &lt;span class="p"&gt;}&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
  &lt;span class="p"&gt;})&lt;/span&gt;

  &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="nx"&gt;range&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kd"&gt;let&lt;/span&gt; &lt;span class="nx"&gt;i&lt;/span&gt; &lt;span class="k"&gt;of&lt;/span&gt; &lt;span class="nx"&gt;rangeOf&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;5&lt;/span&gt;&lt;span class="p"&gt;))&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="nx"&gt;console&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;log&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;i&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;

&lt;span class="c1"&gt;// &amp;gt; 1&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 2&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 3&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 4&lt;/span&gt;
&lt;span class="c1"&gt;// &amp;gt; 5&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Ok, once more, let's go through the code...&lt;/p&gt;

&lt;p&gt;Hey, I hope you're enjoying it, read the rest of this article on my website, so I get some access and comments over there too.&lt;/p&gt;

&lt;p&gt;I worked hard redesigning it and making it super nice for you :) &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;Access it Here&lt;/strong&gt;: &lt;a href="https://nipher.io/the-importance-of-iteration-protocols/"&gt;Post Link&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Thank you!&lt;/p&gt;

</description>
      <category>javascript</category>
      <category>iterator</category>
      <category>iterable</category>
      <category>protocols</category>
    </item>
  </channel>
</rss>
