<?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: Diegoper</title>
    <description>The latest articles on DEV Community by Diegoper (@diegoper).</description>
    <link>https://dev.to/diegoper</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%2F339273%2F0ce00a77-a357-4577-9f58-984f4a84108f.png</url>
      <title>DEV Community: Diegoper</title>
      <link>https://dev.to/diegoper</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/diegoper"/>
    <language>en</language>
    <item>
      <title>How to Reduce Functions in Javascript</title>
      <dc:creator>Diegoper</dc:creator>
      <pubDate>Mon, 23 Mar 2020 22:43:07 +0000</pubDate>
      <link>https://dev.to/diegoper/how-to-reduce-functions-in-javascript-7bl</link>
      <guid>https://dev.to/diegoper/how-to-reduce-functions-in-javascript-7bl</guid>
      <description>&lt;h2&gt;
  
  
  &lt;strong&gt;Run a list of functions and get a list of results:&lt;/strong&gt;
&lt;/h2&gt;

&lt;h3&gt;
  
  
  Hi, I'm a new programmer!
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;I've been studying for a few months&lt;/strong&gt; and would like to share this piece of code that came to mind when I studied about the &lt;strong&gt;Reduce()&lt;/strong&gt; function.&lt;/p&gt;

&lt;p&gt;I know it's something simple, but it could be useful for many people to extend it, comment on it and improve it.&lt;/p&gt;


&lt;div class="runkit-element"&gt;
  &lt;code&gt;
    
  &lt;/code&gt;
  &lt;code&gt;
    
// Run with Node 11 or higher

// DATA-COLLECTING FUNCTIONS
const func1 = () =&amp;gt; { return { user: 'Diego Perdomo' } }
const func2 = () =&amp;gt; { return { skills: ['Js', 'React', 'Node', 'Sql'] } }
const func3 = () =&amp;gt; { return { webs: ['dpercode.com', 'dev.to/diegoper'] } }
const func4 = () =&amp;gt; { return { articles: ['My Article 1', 'My Article 2'] } }

// CREATE ARRAY OF FUNCTIONS
const myFunctions = [func1, func2, func3, func4]

// REDUCE THE FUNCTIONS
const funcReducer = myFunctions.reduce((funcAccumulator, nextFunc) =&amp;gt; {
    let arrayFunc = [];
    funcAccumulator === undefined ?
        arrayFunc.push(nextFunc()) :
        arrayFunc.push(funcAccumulator, nextFunc())
    return arrayFunc.flat();
}, undefined)

// RESULTS
console.log(funcReducer)


  &lt;/code&gt;
&lt;/div&gt;


&lt;pre&gt;
// RESULT
[
  { user: 'Diego Perdomo' },
  { skills: [ 'Js', 'React', 'Node', 'Sql' ] },
  { webs: [ 'dpercode.com', 'dev.to/diegoper' ] },
  { articles: [ 'My Article 1', 'My Article 2' ] }
]

&lt;/pre&gt;

&lt;p&gt;&lt;strong&gt;Thanks for visiting my article...&lt;/strong&gt;&lt;/p&gt;

</description>
      <category>javascript</category>
      <category>node</category>
      <category>reduce</category>
      <category>array</category>
    </item>
  </channel>
</rss>
