# Learning the Building Blocks of the Web: My HTML Learning Takeaways My journey into softwares development at Blockfuse Labs began with an introduction to HTML. It has been an exciting learning process. All the instructors who taught me different HTML topics did a great job of explaining the concepts as clearly as possible. As an aspiring developer, one of the first things you'll learn is how to structure your HTML. Think of HTML like, the skeleton of a webpage. Without a skeleton, you wouldn't see the defined output or all the nice things you see on a webpage. HTML lays the foundation for everything else. Many people feel overwhelmed by learning HTML, but it's important to remember that skipping the basics and jumping to what you think is more advanced will only lead you back to them again and again. In HTML, you don't need to memorize every single element. There are some tags you might only use once or twice while learning, and you may never use them again in your programming journey. However, it's crucial to understand these tags. That way, when you encounter them later, you won't be confused. In this article, I will share my key learnings and hope that anyone who reads it will not only be inspired but also learn a thing or two about HTML. **Getting Started with Coding** You need a place to write your code. * A good choice is Visual Studio Code, which is a free program that helps you write code easily. * You can also use Notepad (if you're using Windows) or TextEdit (if you're using a Mac). **Understanding HTML Elements** In HTML, everything is built using elements. An element consists of an opening tag, some content (which can be text, other elements, or even nothing), and a closing tag. For example: ``` <p> This is a paragraph. It is the content within the paragraph element. </p> <!-- `<p>` is the opening tag for a paragraph and `</p>` is the closing tag for the paragraph. --> ``` **Basic Structure of HTML** * Create an HTML File: Start by creating a new file. You can name it anything you like, but make sure it ends with ".html". This tells the browser that it's an HTML file. * The `<!DOCTYPE html>` Declaration: This is the very first thing in your HTML file. It tells the browser that you're using the latest version of HTML and about to write html documment. * The `<html>` element: This acts as the container for all the content of your webpage. * The `<head>`: The `<head> `section contains information about the webpage that isn't directly visible to users. This includes things like, the `<title>`. Title defines the title that appears in the browser tab. * Meta tags: These tags provide extra information about the webpage, such as keywords for search engines and how the page should be displayed on different devices. * The `<body>`: The <body> section contains all the content that users will see on the webpage, such as text, images, and links. This is what HTML looks like ```html= <!DOCTYPE html> <html> <head> <meta name="author" content="chinemerem"> <meta name = "keywords" content="developer, blog, web-design"/> <meta name="copyright" content ="2025 company.com" /> <meta name="description" content = "HTML Crash Course" /> <meta charset = "utf-8" /> <meta name ="viewport" content = "width=device-width, initial- scale=1.0" /> <title>My Learning Takeaways</title> </head> <body> </body> </html> ``` **Headings** Think of headings as the titles and maybe subtitles of your webpage. They help organize your content and make it easier for both readers and the browser. We use heading tags like` <h1>`, `<h2>`, `<h3>`, and so on. `<h1>` is the largest and most important heading, usually for the main title of the page. The heading size decreases as the number increases, with `<h6>` being the smallest. Using headings properly improves the readability of your page and also helps search engines understand the structure of your content. **Paragraphs** Paragraphs are used to break up your text into smaller, more easily digestible chunks. The `<p>` tag is used to create a new paragraph. Simply place the text you want to appear in a new paragraph within the opening and closing tags ``` <p>This is a paragraph</a> ``` **Links** ```ht= <a href="google.com" target=""_blank>Google Me</a> ``` Links allow you to connect your webpage to other pages on the internet. You can also create an internal links that links to other part of your web page. The `<a>` tag is used to create links.The href attribute within the `<a> `tag specifies the URL of the page you want to link to. Attributes are additional information in an element that adds more functionality to the element. It is normally a key-value pair. In the `<a>` there is another attribute known as “target”. This is used to specific whether the link should open on the same tab or in another tab. **Images** The `<img>` tag is used to insert images into your webpage. Key Attributes * src: Specifies the URL of the image file. * alt: Provides an alternative text description for the image. This is important for screen readers and SEO. The alt is also displayed when your image fails to load. * width and height: Specify the dimensions of the image in pixels. ``` <img src= "" alt="photgrapher" width="200" height="200"> ``` **Lists** The `<ul>` and `<ol>` are used to create unordered and ordered lists respectively. The `<li>` tag is nested within these tags, containing the content for each list item. We also have another kind of list known as a description list. It contains the description term within` <dt>` tags and the corresponding definition within `<dd>` tags. ``` <ul> <li>list item 1</li> <li>list item 2</li> <li>list item 3</li> <li>list item 4</li> </ul> <ol> <li>list item 1</li> <li>list item 2</li> <li>list item 3</li> <li>list item 4</li> </ol> ``` **Tables** Tables are used to display tabular data. They make data more presentable and organized. ``` <table> <thead> <tr> <th>Name</th> <th>Email</th> <th>Age</th> </tr> </thead> <tbody> <tr> <td>Olive</td> <td>olive.com</td> <td>12</td> </tr> <tr> <td>mike</td> <td>mike.com</td> <td>10</td> </tr> <tr> <td>chinemerem</td> <td>chi.com</td> <td>19</td> </tr> </tbody> </table> ``` **Forms** Forms are used to collect inputs from users. They typically consist of labels and input fields with various attributes. Let's create a very simple form: <form action="process.com" method="POST"> <div> <label>First Name<label> <input type="text" name="firstName" > </div> <br> <div> <label>Last Name<label> <input type="text" name="lastName" > </div> <br> <div> <label>Email<label> <input type="email" name="email" > </div> <br> <div> <label>Message<label> <textarea name="message"></textarea> </div> <br> <div> <label>Gender<label> <select name="gender"> <option value ="male">male</option> <option value ="female">female</option> <option value ="other">other</option> </select> </div> <br> <div> <label>Age<label> <input type="number" name="age" value="30"> </div> <br> <div> <label>Birthday<label> <input type="date" name="birthday" > </div> <br> <input type="submit" name="submit" value="Submit"> </form> **What is Semantic HTML?** Semantic HTML is all about using HTML tags that describe the meaning and purpose of the content within them. Instead of just using tags like `<div>`, Semantic HTML uses a tag that is descriptive. This makes your code more readable, maintainable, and accessible for both humans and search engines. Examples of Semantic HTML Elements: `<header>`: For the header section of a page (logo, navigation, etc.). `<nav>`: For navigation links. `<main>`: For the main content area of the page. `<article>`: For a self-contained block of content (like a blog post). `<aside>`: For sidebars or related content. `<footer>`: For the footer section of a page (copyright, contact info, etc.). `<section>`: For a generic section or block of content. ``` <!DOCTYPE html> <html> <head> <meta name="author" content="chinemerem"> <meta name = "keywords" content="developer, blog, web-design"/> <meta name="copyright" content ="2025 company.com" /> <meta name="description" content = "HTML Crash Course" /> <meta charset = "utf-8" /> <meta name ="viewport" content = "width=device-width, initial- scale=1.0" /> <title>My Learning Takeaways</title> </head> <body> <header> <h1>My Goals for the Year</h1> <nav> <ul> <li><a href="learning.html">Learning HTML</a></li> <li><a href="#vacation.html">Planning a Vacation</a></li> <li><a href="#contact.html">Contact Me</a></li> </ul> </nav> </header> <main> <ol> <li>list item 1</li> <li>list item 2</li> <li>list item 3</li> <li>list item 4</li> </ol> </main> <section> <table> <thead> <tr> <th>Name</th> <th>Email</th> <th>Age</th> </tr> </thead> <tbody> <tr> <td>Olive</td> <td>olive.com</td> <td>12</td> </tr> <tr> <td>mike</td> <td>mike.com</td> <td>10</td> </tr> <tr> <td>chinemerem</td> <td>chi.com</td> <td>19</td> </tr> </tbody> </table> </section> <footer> <ul> <li>list item 1</li> <li>list item 2</li> <li>list item 3</li> <li>list item 4</li> </ul> </footer> </body> </html> ``` **My Key Takeaways** **Practice makes perfect**: You don't get good by just looking at the code, you get good by doing it. Make sure to practice what you learned over and over again. **Build different projects**: If you feel like you've learned enough elements, find a web page and try replicating it using what you learned. There's no such thing as learning enough, learning is a continuous process. But don't forget the 80/20 rule, which states that you only need 20% of the effort to achieve 80% of the results. Believe me, this is very much applicable to HTML learning. **Try teaching others what you know**: By doing so, you build muscle memory. For instance, as I am writing this, I am learning more and solidifying my knowledge. Don't forget, this is just like a summary and foundation of HTML. Research more, utilize the resources to broaden your knowledge and get ready for the next step of learning, which is adding colors to your HTML (that's where CSS comes in!). **Resources** HTML: HyperText Markup Language https://developer.mozilla.org/en-US/docs/Web/HTML Learn HTML – Full Tutorial for Beginners https://www.youtube.com/watch?v=kUMe1FH4CHE&t=12316s