<?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: Ayra Austine Baet</title>
    <description>The latest articles on DEV Community by Ayra Austine Baet (@ayra_austine).</description>
    <link>https://dev.to/ayra_austine</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%2F3780981%2F2c604e22-14be-4332-a16c-9854d5e85b6e.jpg</url>
      <title>DEV Community: Ayra Austine Baet</title>
      <link>https://dev.to/ayra_austine</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/ayra_austine"/>
    <language>en</language>
    <item>
      <title>My First React Project (Without Tutorials)</title>
      <dc:creator>Ayra Austine Baet</dc:creator>
      <pubDate>Fri, 20 Feb 2026 23:52:22 +0000</pubDate>
      <link>https://dev.to/ayra_austine/my-first-react-project-without-tutorials-25a4</link>
      <guid>https://dev.to/ayra_austine/my-first-react-project-without-tutorials-25a4</guid>
      <description>&lt;p&gt;Hi, I'm Ayra👋&lt;br&gt;
I'm an aspiring front-end developer, and instead of watching another React tutorial... I decided to build something on my own.&lt;/p&gt;

&lt;p&gt;After practicing HTML, CSS, and JavaScript, I wanted to challenge myself:&lt;/p&gt;

&lt;p&gt;Can I build a React project without following step-by-step guidance?&lt;/p&gt;

&lt;p&gt;So I chose &lt;a href="https://www.frontendmentor.io/challenges/digital-bank-landing-page-WaUhkoDN" rel="noopener noreferrer"&gt;Frontend Mentor's Digital Bank Landing Page Challenge&lt;/a&gt; and rebuilt it using React, even though the challenge was originally meant for plain HTML, CSS and JavaScript.&lt;/p&gt;

&lt;p&gt;Here's what I learned.&lt;/p&gt;
&lt;h2&gt;
  
  
  Why I chose React
&lt;/h2&gt;

&lt;p&gt;React is &lt;strong&gt;component-based&lt;/strong&gt;, which means you can break your UI into small, reusable pieces instead of writing everything in one large file.&lt;/p&gt;

&lt;p&gt;Instead of traditional HTML tags, React uses &lt;strong&gt;JSX&lt;/strong&gt;, which lets you write HTML-like syntax directly inside JavaScript.&lt;/p&gt;

&lt;p&gt;Even more interesting:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;React uses &lt;strong&gt;virtual DOM&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;It applies a &lt;strong&gt;diffing algorithm&lt;/strong&gt;
&lt;/li&gt;
&lt;li&gt;It updates only what has changed&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;That means no manual DOM manipulation. No querySelector. No addEventListener for every interaction.&lt;/p&gt;

&lt;p&gt;Just state → UI&lt;/p&gt;
&lt;h1&gt;
  
  
  Building the Header Component
&lt;/h1&gt;

&lt;p&gt;I started with the Header component.&lt;/p&gt;

&lt;p&gt;Instead of hardcoding navigation links, I stored them in an array and rendered them dynamically using map():&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="nx"&gt;links&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Home&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="s2"&gt;About&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="s2"&gt;Contact&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="s2"&gt;Blog&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="s2"&gt;Careers&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;];&lt;/span&gt;

&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;ul&lt;/span&gt; &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"nav__links"&lt;/span&gt; &lt;span class="na"&gt;aria-label&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"navigation links"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;links&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;map&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nx"&gt;link&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;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;li&lt;/span&gt; &lt;span class="na"&gt;key&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;link&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;a&lt;/span&gt; &lt;span class="na"&gt;href&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"#"&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;link&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;a&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;li&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="p"&gt;))&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;ul&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  Why this matters
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;No duplication&lt;/li&gt;
&lt;li&gt;Easier to maintain&lt;/li&gt;
&lt;li&gt;Scalable if links change&lt;/li&gt;
&lt;li&gt;Cleaner code structure&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;It felt like a small decision, but it made the component much more flexible.&lt;/p&gt;

&lt;h2&gt;
  
  
  Implementing the Mobile Menu (State!)
&lt;/h2&gt;

&lt;p&gt;This was the part that truly made me &lt;em&gt;understand&lt;/em&gt; React.&lt;/p&gt;

&lt;p&gt;In vanilla JavaScript, I would normally:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Select the button&lt;/li&gt;
&lt;li&gt;Add an event listener&lt;/li&gt;
&lt;li&gt;Toggle a class manually&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;In React, we manage UI changes using &lt;strong&gt;state&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Here's how I handled the toggle:&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="k"&gt;import&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="k"&gt;from&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;react&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;Header&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt;
  &lt;span class="kd"&gt;const&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;setIsOpen&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;useState&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="k"&gt;return &lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;
    &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt;
      &lt;span class="na"&gt;className&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="s2"&gt;`toggle &lt;/span&gt;&lt;span class="p"&gt;${&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt; &lt;span class="p"&gt;?&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;toggle--open&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="p"&gt;}&lt;/span&gt;&lt;span class="s2"&gt;`&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;
      &lt;span class="na"&gt;aria-label&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="s"&gt;"menu toggle"&lt;/span&gt;
      &lt;span class="na"&gt;aria-expanded&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;
      &lt;span class="na"&gt;onClick&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&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="nf"&gt;setIsOpen&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="o"&gt;!&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt;
    &lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;span&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;button&lt;/span&gt;&lt;span class="p"&gt;&amp;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;Now, instead of "manually changing the DOM," I just update the state.&lt;/p&gt;

&lt;p&gt;React handles the rest.&lt;/p&gt;

&lt;p&gt;That mental shift of &lt;strong&gt;thinking declaratively instead of imperatively&lt;/strong&gt; was huge for me.&lt;/p&gt;

&lt;h2&gt;
  
  
  Component Architecture and Props
&lt;/h2&gt;

&lt;p&gt;I didn't want my Header component to become too large.&lt;/p&gt;

&lt;p&gt;So I split things into:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;MobileMenu&lt;/li&gt;
&lt;li&gt;Backdrop&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Both depend on the same isOpen state, so I passed it down as props:&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="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nc"&gt;MobileMenu&lt;/span&gt; &lt;span class="na"&gt;links&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;links&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt; &lt;span class="na"&gt;isOpen&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt; &lt;span class="p"&gt;/&amp;gt;&lt;/span&gt;
&lt;span class="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nc"&gt;Backdrop&lt;/span&gt; &lt;span class="na"&gt;isOpen&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;isOpen&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt; &lt;span class="na"&gt;onClose&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&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="nf"&gt;setIsOpen&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="si"&gt;}&lt;/span&gt; &lt;span class="p"&gt;/&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;You can check out the full MobileMenu and Backdrop components in my GitHub repo: &lt;a href="https://github.com/ayra-baet/bank-landing-page-react" rel="noopener noreferrer"&gt;https://github.com/ayra-baet/bank-landing-page-react&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;This made everything:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Cleaner&lt;/li&gt;
&lt;li&gt;More reusable&lt;/li&gt;
&lt;li&gt;Easier to reason about&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;It also forced me to think about:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Where should the state live&lt;/li&gt;
&lt;li&gt;How components communicate&lt;/li&gt;
&lt;li&gt;How to avoid unnecessary duplication&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This is something you don't really experience when building static HTML pages.&lt;/p&gt;

&lt;h2&gt;
  
  
  What This Project Taught Me
&lt;/h2&gt;

&lt;p&gt;Even though I only rebuilt the header section, I learned a lot:&lt;/p&gt;

&lt;h3&gt;
  
  
  1. Component Architecture Matters
&lt;/h3&gt;

&lt;p&gt;Should everything live in one file?&lt;br&gt;
Or should it be broken into smaller pieces?&lt;/p&gt;

&lt;h3&gt;
  
  
  2. State Placement Is Important
&lt;/h3&gt;

&lt;p&gt;If multiple components need the same state, it should probably live higher up.&lt;/p&gt;

&lt;h3&gt;
  
  
  3. Reusability &amp;gt; Repetition
&lt;/h3&gt;

&lt;p&gt;Arrays + props + dynamic rendering = scalable UI&lt;/p&gt;

&lt;h3&gt;
  
  
  4. React Is About Thinking Differently
&lt;/h3&gt;

&lt;p&gt;It's not just "JavaScript with different syntax."&lt;br&gt;
It's a shift in mindset.&lt;/p&gt;

&lt;h2&gt;
  
  
  The Biggest Realization
&lt;/h2&gt;

&lt;p&gt;React felt confusing when I just watched tutorials.&lt;br&gt;
But when I built something on my own, struggled a bit, and solved real UI problems... it finally clicked!&lt;/p&gt;

&lt;h2&gt;
  
  
  What's Next?
&lt;/h2&gt;

&lt;p&gt;In my next post, I'll share how I built the rest of the landing page...&lt;/p&gt;

</description>
      <category>beginners</category>
      <category>react</category>
      <category>frontend</category>
      <category>javascript</category>
    </item>
  </channel>
</rss>
