<?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: Newton Fernandis</title>
    <description>The latest articles on DEV Community by Newton Fernandis (@newtonfdz).</description>
    <link>https://dev.to/newtonfdz</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%2F1142539%2F0fb4720c-77d3-49fd-adbb-7e86a83a4a22.jpg</url>
      <title>DEV Community: Newton Fernandis</title>
      <link>https://dev.to/newtonfdz</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/newtonfdz"/>
    <language>en</language>
    <item>
      <title>[Boost]</title>
      <dc:creator>Newton Fernandis</dc:creator>
      <pubDate>Thu, 11 Sep 2025 16:23:54 +0000</pubDate>
      <link>https://dev.to/newtonfdz/-1ci6</link>
      <guid>https://dev.to/newtonfdz/-1ci6</guid>
      <description>&lt;div class="ltag__link"&gt;
  &lt;a href="/newtonfdz" class="ltag__link__link"&gt;
    &lt;div class="ltag__link__pic"&gt;
      &lt;img src="https://media2.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1142539%2F0fb4720c-77d3-49fd-adbb-7e86a83a4a22.jpg" alt="newtonfdz"&gt;
    &lt;/div&gt;
  &lt;/a&gt;
  &lt;a href="https://dev.to/newtonfdz/why-you-shouldnt-define-a-component-inside-another-component-in-react-30h3" class="ltag__link__link"&gt;
    &lt;div class="ltag__link__content"&gt;
      &lt;h2&gt;Why You Shouldn’t Define a Component Inside Another Component in React&lt;/h2&gt;
      &lt;h3&gt;Newton Fernandis ・ Aug 3&lt;/h3&gt;
      &lt;div class="ltag__link__taglist"&gt;
        &lt;span class="ltag__link__tag"&gt;#react&lt;/span&gt;
        &lt;span class="ltag__link__tag"&gt;#webdev&lt;/span&gt;
        &lt;span class="ltag__link__tag"&gt;#reconciliation&lt;/span&gt;
        &lt;span class="ltag__link__tag"&gt;#javascript&lt;/span&gt;
      &lt;/div&gt;
    &lt;/div&gt;
  &lt;/a&gt;
&lt;/div&gt;


</description>
      <category>react</category>
      <category>webdev</category>
      <category>reconciliation</category>
      <category>javascript</category>
    </item>
    <item>
      <title>Why You Shouldn’t Define a Component Inside Another Component in React</title>
      <dc:creator>Newton Fernandis</dc:creator>
      <pubDate>Sun, 03 Aug 2025 18:31:39 +0000</pubDate>
      <link>https://dev.to/newtonfdz/why-you-shouldnt-define-a-component-inside-another-component-in-react-30h3</link>
      <guid>https://dev.to/newtonfdz/why-you-shouldnt-define-a-component-inside-another-component-in-react-30h3</guid>
      <description>&lt;h2&gt;
  
  
  The Temptation
&lt;/h2&gt;

&lt;p&gt;You’re building a dashboard and need a profile card for the logged-in user.&lt;br&gt;
It’s quick, it’s simple, so you write:&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="nf"&gt;Dashboard&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="nx"&gt;user&lt;/span&gt; &lt;span class="p"&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;ProfileCard&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="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;div&lt;/span&gt; &lt;span class="nx"&gt;className&lt;/span&gt;&lt;span class="o"&gt;=&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;card&lt;/span&gt;&lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
        &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;h2&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;user&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/h2&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;        &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;p&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;user&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;role&lt;/span&gt;&lt;span class="p"&gt;}&lt;/span&gt;&lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/p&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;      &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/div&lt;/span&gt;&lt;span class="err"&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="k"&gt;return &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;div&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;
      &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;h1&lt;/span&gt;&lt;span class="o"&gt;&amp;gt;&lt;/span&gt;&lt;span class="nx"&gt;Dashboard&lt;/span&gt;&lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/h1&lt;/span&gt;&lt;span class="err"&gt;&amp;gt;
&lt;/span&gt;      &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nx"&gt;ProfileCard&lt;/span&gt; &lt;span class="o"&gt;/&amp;gt;&lt;/span&gt;
    &lt;span class="o"&gt;&amp;lt;&lt;/span&gt;&lt;span class="sr"&gt;/div&lt;/span&gt;&lt;span class="err"&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;It works. The UI renders. You move on. 🚀&lt;br&gt;
But lurking under the surface is a performance and state bug just waiting to bite.&lt;/p&gt;
&lt;h2&gt;
  
  
  The Hidden Problem
&lt;/h2&gt;

&lt;p&gt;Every time &lt;code&gt;Dashboard&lt;/code&gt; re-renders, whether because &lt;code&gt;user&lt;/code&gt; changes or some unrelated state updates, React recreates the &lt;code&gt;ProfileCard&lt;/code&gt; function.&lt;/p&gt;

&lt;p&gt;That one fact breaks React’s reconciliation process and can lead to:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;State loss inside ProfileCard&lt;/li&gt;
&lt;li&gt;Extra unmount/mount cycles&lt;/li&gt;
&lt;li&gt;Wasted DOM operations&lt;/li&gt;
&lt;/ul&gt;
&lt;h2&gt;
  
  
  Quick Refresher: What is Reconciliation?
&lt;/h2&gt;

&lt;p&gt;Reconciliation is how React updates the UI without throwing everything away.&lt;/p&gt;

&lt;p&gt;Steps simplified:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Build a &lt;strong&gt;new virtual DOM&lt;/strong&gt; tree from your latest render.&lt;/li&gt;
&lt;li&gt;Compare it to the &lt;strong&gt;previous virtual DOM&lt;/strong&gt; tree.&lt;/li&gt;
&lt;li&gt;Update only the parts that changed in the real DOM.&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;For React to do this efficiently, it relies heavily on &lt;strong&gt;component identity&lt;/strong&gt;.&lt;/p&gt;
&lt;h2&gt;
  
  
  How React Tracks Component Identity
&lt;/h2&gt;

&lt;p&gt;In the virtual DOM, each element has a &lt;code&gt;type&lt;/code&gt; property:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Strings for DOM nodes (&lt;code&gt;'div'&lt;/code&gt;, &lt;code&gt;'span'&lt;/code&gt;, etc.)&lt;/li&gt;
&lt;li&gt;Functions or classes for React components&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;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="p"&gt;{&lt;/span&gt;
  &lt;span class="nl"&gt;type&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nx"&gt;ProfileCard&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="c1"&gt;// function reference&lt;/span&gt;
  &lt;span class="nx"&gt;key&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="kc"&gt;null&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt;
  &lt;span class="nx"&gt;props&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="nl"&gt;name&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="dl"&gt;"&lt;/span&gt;&lt;span class="s2"&gt;Jane&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;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;During reconciliation, React compares the type of the old element and the new element.&lt;br&gt;
The &lt;code&gt;type&lt;/code&gt; is the function or class reference for a component, or a string for a DOM element (like &lt;code&gt;'div'&lt;/code&gt; or &lt;code&gt;'span'&lt;/code&gt;).&lt;/p&gt;

&lt;p&gt;If the type changes, React assumes:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;“This is a completely different component.”&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;When that happens, React will:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Unmount the old component (run cleanup effects, discard state).&lt;/li&gt;
&lt;li&gt;Mount the new one from scratch (run the function body fresh, initialize hooks).&lt;/li&gt;
&lt;/ul&gt;
&lt;h2&gt;
  
  
  The Problem with Inline Components
&lt;/h2&gt;

&lt;p&gt;When you define a component inside another component:&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;function&lt;/span&gt; &lt;span class="nf"&gt;Dashboard&lt;/span&gt;&lt;span class="p"&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;ProfileCard&lt;/span&gt;&lt;span class="p"&gt;()&lt;/span&gt; &lt;span class="p"&gt;{&lt;/span&gt; &lt;span class="cm"&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;&amp;lt;&lt;/span&gt;&lt;span class="nc"&gt;ProfileCard&lt;/span&gt; &lt;span class="p"&gt;/&amp;gt;;&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;React creates a brand-new component on every render.&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;On &lt;strong&gt;render #1&lt;/strong&gt;, &lt;code&gt;type&lt;/code&gt; = &lt;code&gt;ProfileCard@0x001&lt;/code&gt; (memory address A)&lt;/li&gt;
&lt;li&gt;On &lt;strong&gt;render #2&lt;/strong&gt;, &lt;code&gt;type&lt;/code&gt; = &lt;code&gt;ProfileCard@0x002&lt;/code&gt; (memory address B)&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;They may look the same in code, but they are &lt;strong&gt;different function objects in memory&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;React’s check:&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;oldFiber&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;type&lt;/span&gt; &lt;span class="o"&gt;!==&lt;/span&gt; &lt;span class="nx"&gt;newFiber&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;type&lt;/span&gt; &lt;span class="c1"&gt;// true&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;And that triggers a &lt;strong&gt;full unmount + mount&lt;/strong&gt;.&lt;/p&gt;

&lt;p&gt;Result:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Any local state in &lt;code&gt;ProfileCard&lt;/code&gt; is lost.&lt;/li&gt;
&lt;li&gt;Effects run cleanup + re-run from scratch.&lt;/li&gt;
&lt;li&gt;DOM nodes are destroyed and recreated.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Real-World Impact
&lt;/h2&gt;

&lt;p&gt;Let’s say &lt;code&gt;ProfileCard&lt;/code&gt; has a form for editing user info:&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;function&lt;/span&gt; &lt;span class="nf"&gt;ProfileCard&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;editing&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;setEditing&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="c1"&gt;// form logic...&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;If &lt;code&gt;Dashboard&lt;/code&gt; re-renders due to a theme change or notification count update:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Old &lt;code&gt;ProfileCard&lt;/code&gt; is unmounted.&lt;/li&gt;
&lt;li&gt;New &lt;code&gt;ProfileCard&lt;/code&gt; is mounted.&lt;/li&gt;
&lt;li&gt;
&lt;code&gt;editing&lt;/code&gt; resets to &lt;code&gt;false&lt;/code&gt;.&lt;/li&gt;
&lt;li&gt;Your user loses unsaved changes. 😬&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  The Correct Approach
&lt;/h2&gt;

&lt;p&gt;Move &lt;code&gt;ProfileCard&lt;/code&gt; out so its identity is stable:&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;function&lt;/span&gt; &lt;span class="nf"&gt;ProfileCard&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="nx"&gt;role&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="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&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;"card"&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;h2&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;name&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;h2&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;p&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;role&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;p&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;div&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;span class="kd"&gt;function&lt;/span&gt; &lt;span class="nf"&gt;Dashboard&lt;/span&gt;&lt;span class="p"&gt;({&lt;/span&gt; &lt;span class="nx"&gt;user&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="p"&gt;&amp;lt;&lt;/span&gt;&lt;span class="nt"&gt;div&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;h1&lt;/span&gt;&lt;span class="p"&gt;&amp;gt;&lt;/span&gt;Dashboard&lt;span class="p"&gt;&amp;lt;/&lt;/span&gt;&lt;span class="nt"&gt;h1&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;ProfileCard&lt;/span&gt; &lt;span class="na"&gt;name&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;user&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;name&lt;/span&gt;&lt;span class="si"&gt;}&lt;/span&gt; &lt;span class="na"&gt;role&lt;/span&gt;&lt;span class="p"&gt;=&lt;/span&gt;&lt;span class="si"&gt;{&lt;/span&gt;&lt;span class="nx"&gt;user&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nx"&gt;role&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;div&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:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;ProfileCard&lt;/code&gt; keeps the same reference across renders.&lt;/li&gt;
&lt;li&gt;React preserves state and DOM.&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  Takeaway
&lt;/h2&gt;

&lt;p&gt;React’s reconciliation is built on &lt;strong&gt;stable component identity&lt;/strong&gt;.&lt;br&gt;
Defining components inside other components breaks that stability, causing unnecessary unmounts and state loss.&lt;/p&gt;

</description>
      <category>react</category>
      <category>webdev</category>
      <category>reconciliation</category>
      <category>javascript</category>
    </item>
  </channel>
</rss>
