7 Alternatives to the <div> HTML Tag
Updated: February 12, 2022•4 min read
Does your HTML markup look like this 👆?
So you've made a delicious div soup?, no problem. I'm here to help.
Writing Semantic HTML gives your markup meaning to web browsers and screen readers and helps with SEO which brings your website on top of search engine results.
“The
div
element has no special meaning at all…Authors are strongly encouraged to view thediv
element as an element of last resort, for when no other element is suitable. Use of more appropriate elements instead of thediv
element leads to better accessibility for readers and easier maintainability for authors.”
The Main
Element
The main element indicates to browsers and screen readers which portion of your markup contains the main section of content on a given page. This can help with keyboard command access, zooming on mobile browsers, and more. It should be used only once per page.
<main><h1>Most Popular Browsers</h1><p>Chrome, Firefox, and Edge are the most used browsers today.</p><article><h2>Google Chrome</h2><p>Google Chrome is a web browser developed by Google, released in 2008.Chrome is the world's most popular web browser today!</p></article><article><h2>Mozilla Firefox</h2><p>Mozilla Firefox is an open-source web browser developed by Mozilla.Firefox has been the second most popular web browser since January, 2018.</p></article><article><h2>Microsoft Edge</h2><p>Microsoft Edge is a web browser developed by Microsoft, released in 2015.Microsoft Edge replaced Internet Explorer.</p></article></main>
The Section
Element
The section element is used to group content by theme and represents a section of a document or application. Sections can have their own header
and footer
elements, and there can be multiple section
elements used on a single page.
<section><h2>WWF History</h2><p>The World Wide Fund for Nature (WWF) is an international organizationworking on issues regarding the conservation, research and restoration ofthe environment, formerly named the World Wildlife Fund. WWF was founded in1961.</p></section><section><h2>WWF's Symbol</h2><p>The Panda has become the symbol of WWF. The well-known panda logo of WWForiginated from a panda named Chi Chi that was transferred from the BeijingZoo to the London Zoo in the same year of the establishment of WWF.</p></section>
The Aside
Element
The aside elements are mainly used to represent part of a page containing related content to a given section. Asides are typically used as sidebars.
<p>My family and I visited The Epcot center this summer. The weather was nice,and Epcot was amazing! I had a great summer together with my family!</p><aside><h4>Epcot Center</h4><p>Epcot is a theme park at Walt Disney World Resort featuring excitingattractions, international pavilions, award-winning fireworks and seasonalspecial events.</p></aside>
The Article
Element
The article element can be used for portions of content that could stand on their own. Blog posts, newspaper articles, and user comments are some possible use cases the the article
element.
<article><h2>Google Chrome</h2><p>Google Chrome is a web browser developed by Google, released in 2008. Chromeis the world's most popular web browser today!</p></article><article><h2>Mozilla Firefox</h2><p>Mozilla Firefox is an open-source web browser developed by Mozilla. Firefoxhas been the second most popular web browser since January, 2018.</p></article><article><h2>Microsoft Edge</h2><p>Microsoft Edge is a web browser developed by Microsoft, released in 2015.Microsoft Edge replaced Internet Explorer.</p></article>
The Blockquote
Element
The blockquote element represents content that is being quoted from an external source (a person, document, newspaper, case study, etc.). It is often accompanied by the cite
element to attribute the quote to its source.
<blockquote cite="http://www.worldwildlife.org/who/index.html">For 50 years, WWF has been protecting the future of nature. The world'sleading conservation organization, WWF works in 100 countries and is supportedby 1.2 million members in the United States and close to 5 million globally.</blockquote>
The Nav
Element
The nav elements represent the navigation section of a document. The nav
element should include the primary navigation links for a give page, application, etc.
<nav><a href="/html/">HTML</a> | <a href="/css/">CSS</a> |<a href="/js/">JavaScript</a> |<a href="/python/">Python</a></nav>
The Header
Element
The header element represents the “header” section of a document or section. In many websites, the header
element will contain introductory content but also a logo, a search form, an author name.
<header><h1>A heading here</h1><p>Posted by John Doe</p><p>Some additional information here</p></header>
The Footer
Element
The footer element represents the “footer” section of a document or section. In many websites, the footer
element will contain contact and copyright information, a brief “about” blurb, social media logos and links, etc.
<header><p>Author: Hege Refsnes</p><p><a href="mailto:hege@example.com">hege@example.com</a></p></header>
Now that we know about some semantically optimized alternatives to the div
element, how do we know when to use each of them? And when (if ever) is it ok to still use div
elements in our markup? HTML5 Doctor has a really handy flowchart to help answer that question: