<?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: Gene Lorenz Sarmiento</title>
    <description>The latest articles on DEV Community by Gene Lorenz Sarmiento (@glsarmiento).</description>
    <link>https://dev.to/glsarmiento</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%2F809313%2Fc7ebc1eb-1f27-4963-8a8d-ab0802fe8bf8.jpg</url>
      <title>DEV Community: Gene Lorenz Sarmiento</title>
      <link>https://dev.to/glsarmiento</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/glsarmiento"/>
    <language>en</language>
    <item>
      <title>About React UseEffect</title>
      <dc:creator>Gene Lorenz Sarmiento</dc:creator>
      <pubDate>Fri, 04 Feb 2022 12:41:48 +0000</pubDate>
      <link>https://dev.to/glsarmiento/about-react-useeffect-kdf</link>
      <guid>https://dev.to/glsarmiento/about-react-useeffect-kdf</guid>
      <description>

&lt;p&gt;By Gene Lorenz Sarmiento &lt;/p&gt;

&lt;p&gt;Last Edited: February 4, 2021 8:10 pm GMT+08:00&lt;/p&gt;

&lt;p&gt;I made this article about useEffect via Scrimba’s free React lesson (&lt;a href="https://scrimba.com/learn/learnreact"&gt;https://scrimba.com/learn/learnreact&lt;/a&gt;).&lt;/p&gt;

&lt;p&gt;First, what is a side effect in React. A side effect is an effect that React can’t handle on its own:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;(Out)side effects! The examples of it are:

&lt;ul&gt;
&lt;li&gt;localStorage&lt;/li&gt;
&lt;li&gt;API/database Interactions&lt;/li&gt;
&lt;li&gt;Subscription (e.g. Websockets)&lt;/li&gt;
&lt;li&gt;Syncing 2 different internal states together.&lt;/li&gt;
&lt;li&gt;Basically anything that React in not in charge for.&lt;/li&gt;
&lt;/ul&gt;


&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;&lt;a href="https://res.cloudinary.com/practicaldev/image/fetch/s--h7Y4xoaK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/3kdggsuuzax39bhxgsa7.png" class="article-body-image-wrapper"&gt;&lt;img src="https://res.cloudinary.com/practicaldev/image/fetch/s--h7Y4xoaK--/c_limit%2Cf_auto%2Cfl_progressive%2Cq_auto%2Cw_880/https://dev-to-uploads.s3.amazonaws.com/uploads/articles/3kdggsuuzax39bhxgsa7.png" alt="Credits to [Scrimba](https://scrimba.com)" width="880" height="465"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;If you are familiar with class-based components, you can think of the useEffect() as the &lt;code&gt;componentDidMount&lt;/code&gt;, &lt;code&gt;componentDidUpdate&lt;/code&gt;, and &lt;code&gt;componentWillUnmount&lt;/code&gt; to control side effects. In functional components, you can use hooks(which is like Class-lifecycle methods in React). One of the hooks is called useEffect()&lt;/p&gt;

&lt;p&gt;The &lt;em&gt;Effect Hook&lt;/em&gt; lets you perform side effects in functional components&lt;/p&gt;

&lt;p&gt;UseEffect will run when every component is rendered&lt;/p&gt;

&lt;p&gt;2 parameters (1 is a callback function and 1 optional (This can be required) )&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;count&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;setCount&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nx"&gt;React&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;useState&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;);&lt;/span&gt;
&lt;span class="c1"&gt;// side effects&lt;/span&gt;
    &lt;span class="nx"&gt;React&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;useEffect&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="kd"&gt;function&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="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Effect ran&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="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;count&lt;/span&gt;&lt;span class="p"&gt;])&lt;/span&gt; 
&lt;span class="c1"&gt;// 1st param - Callback function&lt;/span&gt;
&lt;span class="c1"&gt;// 2nd param - dependencies array&lt;/span&gt;
&lt;span class="c1"&gt;// First parameter run when the 2nd parameter changed/re-rendered&lt;/span&gt;
&lt;span class="cm"&gt;/* if the second parameter is an empty array [], 
it will not render every time that any state has change
*/&lt;/span&gt;
&lt;span class="c1"&gt;// useEffect() depends on the 2nd parameter if it should run &lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;To clean up the side effects, you should return the value of it.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight jsx"&gt;&lt;code&gt;&lt;span class="nx"&gt;React&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;useEffect&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="kd"&gt;function&lt;/span&gt; &lt;span class="nx"&gt;watchWidth&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
            &lt;span class="nx"&gt;setWindowWidth&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nb"&gt;window&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;innerWidth&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
        &lt;span class="p"&gt;}&lt;/span&gt;
        &lt;span class="cm"&gt;/* can cause a memory leak (if the component was removed on the DOM)
                * if not removed on return */&lt;/span&gt;
        &lt;span class="nb"&gt;window&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;addEventListener&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;resize&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;watchWidth&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;

        &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="kd"&gt;function&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
            &lt;span class="nb"&gt;window&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;removeEventListener&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;resize&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;watchWidth&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="p"&gt;[])&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  References:
&lt;/h3&gt;

&lt;p&gt;&lt;a href="https://reactjs.org/docs/hooks-effect.html"&gt;https://reactjs.org/docs/hooks-effect.html&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://scrimba.com/learn/learnreact"&gt;https://scrimba.com/learn/learnreact&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;More Graphics:  &lt;a href="https://funky-cuticle-9ef.notion.site/About-React-UseEffect-ea0c2342c07c4c42958659bca33fcbb6"&gt;https://funky-cuticle-9ef.notion.site/About-React-UseEffect-ea0c2342c07c4c42958659bca33fcbb6&lt;/a&gt;&lt;/p&gt;

</description>
    </item>
  </channel>
</rss>
