An agency building with Duda recently asked me about semantic HTML tags, a conversation that really activated the curious side of my brain. With modernweb designand HTML5, there are a range of semantic HTML tags that help people and robots reading your website’s code understand the structure and context of the content on a page.
Anyone who’s been around the web is familiar with the classic tags: <p> for paragraph, <table> for a structured table, <h1> - <h6> for heading sizes. These are the classic semantic tags of HTML. You might even be familiar with a bit more specific tags such as <nav> for navigation, <article> for blog or news articles, <header> and <footer>, etc.
On its own, semantic HTML is a great tool that makes websites easier to understand and parse. But, this made me curious about all the different HTML tags that exist officially as part of HTML 5 and sent me down a rabbit hole of fun (yes, this is my idea of fun on a Tuesday night). So, I thought I’d share my findings.
Some of these tags are actually pretty powerful, some are just kind of fun and some can be used for semantic situations. Really, the point here is just to show you there is much more to HTML than meets the eye.
Let's take a more in-depth look at each one of the HTML tags I've listed above.
1. <del> and <ins>
There is actually a tag for text that is struck-through and another that indicates the replacement text. This comes directly out of the semantic playbook to show that a piece of text should be deleted.
An example of this is: "Plutoisisn't a planet."
In HTML, here is how that looks:
HTML
<p>Pluto<del>is</del> <ins>isn’t</ins> a planet.</p>
If you want to be extra fancy, you can even include a "datetime" attribute on the <ins> tag to show when the new text was added or amended.
2. <abbr>
“abbr” is short for abbreviation! (Would you ever have guessed?) The idea here is that if you use a title (e.g. “Mr.”) or acronym (e.g. “POTUS”), the abbr tag indicates exactly what that abbreviation means.
For example:
HTML
<p><abbr title="President of The United States">POTUS</abbr> rode his bicycle into a tree.</p>
What’s great here is that you can clearly see in the code that the abbreviation tag gives context as to what exactly the shorthand means.
3. <meter>
The next two elements in our list are similar, but definitely not the same. Meter is a built-in range to give an indication of good, medium or bad results. Whenbuilding a website, this gauge is a nifty tool built into browsers that is normally created using much more custom code and JavaScript.
Both the progress and meter tags display bars on a web page. However, the progress tag is designed to show how far along something is, such as a project or task.
For example, if you wanted to show a project is 70 percent complete, you could use this HTML:
And here is what that would look like on the page:
5. <details> and <summary>
Did you know HTML has a built-in accordion feature? Most websites that implement some type of accordion rely on JavaScript to implement the ‘open and close’ experience, but this is actually a native feature of HTML5.
Here is an example of what this looks like in HTML:
HTML
<details>
<summary>Details</summary>
Something small enough to escape casual notice.
</details>
<details open>
<summary>Item 2</summary>
Something else. This one defaults to open!
</details>
And here is an example of what this looks like when it's running:
Details
Something small enough to escape casual notice.Item 2
Something else. This one defaults to open!
6. <blockquote> & <cite>
If you’re including content from a different source, you should absolutely cite that source (yes, just like in college). The blockquote and cite HTML tags are the semantic version of this that indicate the content is from an outside source.
<p>It is not the critic who counts; not the man who points out how the strong man stumbles, or where the doer of deeds could have done them better...</p>
</blockquote>
<figcaption>Teddy Roosevelt, <cite>Citizenship in a Republic Speach</cite></figcaption>
</figure>
And here is how that looks on the page:
7. <time>
The time element is both semantic and structured data. It tries to tell crawlers and bots what time exactly is being referenced. A perfect example of where this can be used is in the post date of an article, blog post or page. Most clients or businesses will want this added to the blog section of a website, so if you’re offering awhite label serviceit’s always worthwhile suggesting it as it’s a handy tag to have in your back pocket.
Now, this element does not have a special display and will simply look like all the text around it; but, it provides much more context to any computer or person reading it!
8. <datalist>
The datalist tag is one I really wish more developers knew about. Often, developers will use complex JavaScript libraries to implement this exact same functionality, even though it already exists in HTML!
A datalist is an advanced drop-down to select something in a form. The nice thing is that it works as both a search and a drop-down.
Here is an example of how to implement this tag in HTML:
And here’s a simple example of what this looks like in action:
9. <mark>
If your website is informational and you really want to highlight a key point, then you can do so using the <mark> tag. It’s a way to highlight a block of text, just as you would in a Google Sheets or Word doc, with the option of also customizing the highlighted color. This can be done using the “background-color” CSS property within the <mark> tag, while the text color can be altered with the “color” property.
Here is an example of how to use the <mark> tag:
HTML
<mark> It is not the critic who counts; not the man who points out how the strong man stumbles, or where the doer of deeds could have done them better… </mark>
10. <audio>
With audio becoming more and more important when building a website, boosting both user experience and SEO value of a website, the <audio> HTML tag is a really useful addition, particularly ifadding audiodoes suit the search intent of the user.
The <audio> tag will define a sound and there are three supported files which the tag can be used with. These are MP3, WAV and OGG. How you implement the audio tag into a page is by placing one or more <source> tags with different audio sources. A browser will then select the first one it supports.
Should the browser not support audio, it will then display the text that is between the <audio> elements. It’s becoming more and more of a common tag as audio continues to become more popular with sites, so if you are offering this kind ofsoftware as a serviceand building websites with audio, then it’s certainly one to consider.
Here’s an example of how this HTML tag looks:
HTML
<audio controls>
<source src=”house.ogg” type=”audio/ogg”>
<source src=”house.mp3” type=”audio/mpeg”>
Your browser does not support this audio
</audio>
Conclusion
As you can see, there are a lot of great HTML5-based tags out there and I’ve only scratched the surface. HTML5 has done wonders for the web and continues to be a place of great innovation in browsers. Let’s all just hope that browser vendors continue to extend and add easy to use core HTML elements like these into the future!
he majority of agencies are stuck in a race to the bottom price-wise and are totally dependent on founder-led sales. What if it didn’t have to be that way?
The design of a website is, in many ways, a form of fashion. It’s an art. Just like fashion, your websites can “fall out of style” as public opinion shifts over time. To give your clients the very best, you need to be selling design refreshes.
Duda, the web building platform for digital agencies, SaaS platforms, and web professionals, was recognized by Built In’s 2025 Best Places to Work Awards.