Markup from hell

A collection of bad practices in HTML, copied from real websites.

  1. #23 A card pattern

    submitted on by Erik
    <article>
    <div>
    <div class="sr-only">Image</div>
    <img src="/feature-teaser.png" alt="Feature teaser" />
    </div>
    </article>
    <div>
    <span>
    <span>Exciting feature!</span>
    </span>
    <div> This text describes what the feature does! </div>
    <a href="/blog/feature">
    <span>Read more</span>
    <svg viewBox="0 0 9 12" xmlns="http://www.w3.org/2000/svg">
    <path d="M.84 10.59L5.42 6 .84 1.41 2.25 0l6 6-6 6z"></path>
    </svg>
    </a>
    </div>

    Details and tips on how to fix the diabolic code of #23.

  2. #22 the good ol’ div link

    submitted on by Manuel
    <div>About us</div>

    Details and tips on how to fix the diabolic code of #22.

  3. #21 Legendary legend!

    submitted on by vavroom
    <button class="panel-heading" tabindex="0" href="#collapse0" aria-expanded="true">
    <legend> Industries Served </legend>
    </button>

    Details and tips on how to fix the diabolic code of #21.

  4. #20 HTMHell special: close buttons

    submitted on by Manuel

    This first HTMHell special inspects one of the most complicated and most controversial patterns in front-end development:

    🔥 the close button. 🔥

    In modals, ads, and other overlays you often find a button with a close symbol that allows users, or at least some of them, to close the overlay. This functionality is often limited to mouse users, because most implementations of close buttons suck.

    After less than 2 hours of research, HTMHell presents a collection of 11 different bad practices.

    <div class="close"></div>

    Details and tips on how to fix the diabolic code of #20.

  5. #19 heading in the wrong direction

    submitted on by Šime
    <h1>Product Status</h1>
    <h2>Is the product available?</h2>
    <div>
    <h3>
    <div>
    <div>
    <i>
    <h3 class="message is-success">
    It‘s <a>available</a>.
    </h3>
    </i>
    </div>
    </div>
    </h3>
    </div>

    Details and tips on how to fix the diabolic code of #19.