<?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: Bay Area Ninja</title>
    <description>The latest articles on DEV Community by Bay Area Ninja (@bay_area_ninja).</description>
    <link>https://dev.to/bay_area_ninja</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%2F847618%2Ffe3d0048-2a84-472d-9794-42e248de9fa3.jpg</url>
      <title>DEV Community: Bay Area Ninja</title>
      <link>https://dev.to/bay_area_ninja</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/bay_area_ninja"/>
    <language>en</language>
    <item>
      <title>#help useRef within useEffect</title>
      <dc:creator>Bay Area Ninja</dc:creator>
      <pubDate>Fri, 15 Apr 2022 00:47:56 +0000</pubDate>
      <link>https://dev.to/bay_area_ninja/help-useref-within-useeffect-468o</link>
      <guid>https://dev.to/bay_area_ninja/help-useref-within-useeffect-468o</guid>
      <description>&lt;p&gt;my Goal: Is to create a simple effect that prints out a string one letter at a time.&lt;/p&gt;

&lt;p&gt;example: string = "TEXT". it should print T E X T&lt;/p&gt;

&lt;p&gt;Whats currently being printed is: T X T undefined&lt;/p&gt;

&lt;p&gt;my code: &lt;/p&gt;

&lt;p&gt;`const [placeholder, setPlaceholder] = useState('');&lt;br&gt;
const&lt;br&gt;
    string = 'TEXT',&lt;br&gt;
    index = useRef(0);&lt;/p&gt;

&lt;p&gt;useEffect(() =&amp;gt; {&lt;br&gt;
    function showChar() {&lt;br&gt;
      setPlaceholder(prev =&amp;gt; prev + string[index.current]);&lt;br&gt;
      console.log(index.current)&lt;br&gt;
      index.current++;&lt;br&gt;
    }&lt;br&gt;
    if (index.current &amp;lt; string.length) {&lt;br&gt;
      let addChar = setInterval(showChar, 500);&lt;br&gt;
      return () =&amp;gt; clearInterval(addChar);&lt;br&gt;
    }&lt;br&gt;
  }, [placeholder]);&lt;/p&gt;

&lt;p&gt;return (&lt;br&gt;
    &lt;/p&gt;
&lt;br&gt;
      {placeholder}&lt;br&gt;
    &lt;br&gt;
  )

&lt;p&gt;export default App;`&lt;/p&gt;

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