<?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: Varun Chowdary</title>
    <description>The latest articles on DEV Community by Varun Chowdary (@varun_chowdary_8a4404a06b).</description>
    <link>https://dev.to/varun_chowdary_8a4404a06b</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%2F1536803%2F16000b0d-47c4-4743-b3e3-6cda21ea6cc4.jpg</url>
      <title>DEV Community: Varun Chowdary</title>
      <link>https://dev.to/varun_chowdary_8a4404a06b</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/varun_chowdary_8a4404a06b"/>
    <language>en</language>
    <item>
      <title>From Shitty Code to Solid Dev: Mastering HTML the Right Way</title>
      <dc:creator>Varun Chowdary</dc:creator>
      <pubDate>Tue, 08 Jul 2025 17:03:16 +0000</pubDate>
      <link>https://dev.to/varun_chowdary_8a4404a06b/from-shitty-code-to-solid-dev-mastering-html-the-right-way-152l</link>
      <guid>https://dev.to/varun_chowdary_8a4404a06b/from-shitty-code-to-solid-dev-mastering-html-the-right-way-152l</guid>
      <description>&lt;p&gt;Ever written HTML so bad your CSS gave up?&lt;br&gt;
That was me — spans pretending to be headings, divs nesting deeper than my weekend plans. 😅&lt;br&gt;
This is &lt;strong&gt;Post #1&lt;/strong&gt; in my &lt;strong&gt;Frontend Clean Code Series&lt;/strong&gt; — a guide to writing clean, purposeful HTML, CSS, and Angular/React templates your future self (and teammates) will thank you for.&lt;/p&gt;




&lt;h2&gt;
  
  
  💡 Why HTML Matters
&lt;/h2&gt;

&lt;p&gt;HTML is the &lt;strong&gt;skeleton&lt;/strong&gt; of your app. Mess it up, and everything else — CSS, JavaScript, Angular — starts to break or gets harder to work with.&lt;/p&gt;

&lt;p&gt;Good HTML is:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;✅ &lt;strong&gt;Semantic&lt;/strong&gt;: Uses meaningful tags like &lt;code&gt;&amp;lt;header&amp;gt;&lt;/code&gt;, &lt;code&gt;&amp;lt;main&amp;gt;&lt;/code&gt;, &lt;code&gt;&amp;lt;article&amp;gt;&lt;/code&gt;
&lt;/li&gt;
&lt;li&gt;✅ &lt;strong&gt;Accessible&lt;/strong&gt;: Helps screen readers and assistive tools understand your layout&lt;/li&gt;
&lt;li&gt;✅ &lt;strong&gt;Maintainable&lt;/strong&gt;: Easier to debug and collaborate on in teams&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  ⚠️ Mistake 1: Non-Semantic HTML
&lt;/h2&gt;

&lt;h3&gt;
  
  
  🚫 &lt;em&gt;Code I used to write back in the day:&lt;/em&gt;
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;span&lt;/span&gt; &lt;span class="na"&gt;class=&lt;/span&gt;&lt;span class="s"&gt;"title"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;h4&amp;gt;&lt;/span&gt;My Blog&lt;span class="nt"&gt;&amp;lt;/h4&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/span&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;div&lt;/span&gt; &lt;span class="na"&gt;class=&lt;/span&gt;&lt;span class="s"&gt;"content"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;div&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;div&amp;gt;&lt;/span&gt;
      &lt;span class="nt"&gt;&amp;lt;p&amp;gt;&lt;/span&gt;Welcome to my site!&lt;span class="nt"&gt;&amp;lt;/p&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  😬 What’s wrong here?
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Wrapping a heading (&lt;code&gt;&amp;lt;h4&amp;gt;&lt;/code&gt;) in a &lt;code&gt;&amp;lt;span&amp;gt;&lt;/code&gt; is &lt;strong&gt;meaningless&lt;/strong&gt; and bad for accessibility&lt;/li&gt;
&lt;li&gt;Unnecessary &lt;code&gt;&amp;lt;div&amp;gt;&lt;/code&gt; nesting makes &lt;strong&gt;CSS selectors a nightmare&lt;/strong&gt; (e.g., &lt;code&gt;.content div div p&lt;/code&gt;)&lt;/li&gt;
&lt;li&gt;No clear structure — your teammates (and Google) won’t know what’s going on&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  ✅ The Fix: Use Semantic Tags
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;header&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;h1&amp;gt;&lt;/span&gt;My Blog&lt;span class="nt"&gt;&amp;lt;/h1&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/header&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;main&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;p&amp;gt;&lt;/span&gt;Welcome to my site!&lt;span class="nt"&gt;&amp;lt;/p&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/main&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  💡 Why It’s Better
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;strong&gt;Accessibility&lt;/strong&gt;: Screen readers recognize &lt;code&gt;&amp;lt;h1&amp;gt;&lt;/code&gt; as the main heading&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Simplicity&lt;/strong&gt;: Fewer tags = less CSS, faster rendering&lt;/li&gt;
&lt;li&gt;
&lt;strong&gt;Teamwork&lt;/strong&gt;: Easier to understand in Angular/React templates when working with others&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  ⚠️ Mistake 2: Overusing &lt;code&gt;&amp;lt;div&amp;gt;&lt;/code&gt; for Everything
&lt;/h2&gt;

&lt;h3&gt;
  
  
  🚫 I used to write things like:
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;div&lt;/span&gt; &lt;span class="na"&gt;class=&lt;/span&gt;&lt;span class="s"&gt;"container"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;div&lt;/span&gt; &lt;span class="na"&gt;class=&lt;/span&gt;&lt;span class="s"&gt;"nav"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;div&amp;gt;&lt;/span&gt;Home&lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;div&amp;gt;&lt;/span&gt;About&lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/div&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  😬 What’s wrong?
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;Using &lt;code&gt;&amp;lt;div&amp;gt;&lt;/code&gt;s for everything makes your HTML messy and confusing.&lt;/li&gt;
&lt;li&gt;It’s like putting all your things in one box without sorting or labeling anything.&lt;/li&gt;
&lt;/ul&gt;

&lt;h3&gt;
  
  
  ✅ The Fix: Use Semantic Tags like &lt;code&gt;&amp;lt;nav&amp;gt;&lt;/code&gt;, &lt;code&gt;&amp;lt;ul&amp;gt;&lt;/code&gt;, &lt;code&gt;&amp;lt;li&amp;gt;&lt;/code&gt;
&lt;/h3&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="nt"&gt;&amp;lt;nav&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;ul&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;li&amp;gt;&amp;lt;a&lt;/span&gt; &lt;span class="na"&gt;href=&lt;/span&gt;&lt;span class="s"&gt;"/"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;Home&lt;span class="nt"&gt;&amp;lt;/a&amp;gt;&amp;lt;/li&amp;gt;&lt;/span&gt;
    &lt;span class="nt"&gt;&amp;lt;li&amp;gt;&amp;lt;a&lt;/span&gt; &lt;span class="na"&gt;href=&lt;/span&gt;&lt;span class="s"&gt;"/about"&lt;/span&gt;&lt;span class="nt"&gt;&amp;gt;&lt;/span&gt;About&lt;span class="nt"&gt;&amp;lt;/a&amp;gt;&amp;lt;/li&amp;gt;&lt;/span&gt;
  &lt;span class="nt"&gt;&amp;lt;/ul&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;/nav&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  💡 Why It’s Better
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;
&lt;code&gt;&amp;lt;nav&amp;gt;&lt;/code&gt; + &lt;code&gt;&amp;lt;ul&amp;gt;&lt;/code&gt; tells browsers, screen readers, and other devs: &lt;em&gt;"This is navigation!"&lt;/em&gt;
&lt;/li&gt;
&lt;li&gt;Makes styling and responsiveness easier (especially in React/Angular apps)&lt;/li&gt;
&lt;/ul&gt;




&lt;h2&gt;
  
  
  🔁 My Advice to Beginners
&lt;/h2&gt;

&lt;p&gt;When I started, I treated HTML like a placeholder for JavaScript and CSS. But over time, I learned that &lt;strong&gt;clean, semantic HTML&lt;/strong&gt; is the &lt;strong&gt;foundation&lt;/strong&gt; of everything else.&lt;/p&gt;

&lt;p&gt;&lt;code&gt;✨ Think of HTML like writing a resume — it should be structured, clear, and readable without styling.&lt;/code&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  📌 Coming Up Next
&lt;/h2&gt;

&lt;p&gt;In the next post, I’ll tackle how &lt;strong&gt;CSS can either style your dreams or spiral into spaghetti&lt;/strong&gt; 🍝&lt;br&gt;
Follow me for &lt;strong&gt;Post #2: “How to Avoid CSS Chaos (and Still Look Cool)”&lt;/strong&gt;&lt;/p&gt;

&lt;h2&gt;
  
  
  🙌 Let’s Connect
&lt;/h2&gt;

&lt;p&gt;💬 Have your own HTML horror story? Drop it in the comments — let’s laugh and learn together.&lt;br&gt;
👀 Follow me here for more regular front-end tips and dev life posts.&lt;/p&gt;

</description>
      <category>webdev</category>
      <category>html</category>
      <category>beginners</category>
      <category>coding</category>
    </item>
  </channel>
</rss>
