Much of the excitement we’ve seen so far about HTML5 has been for the new APIs: local storage, application cache, Web workers, 2-D drawing and the like. But let’s not overlook that HTML5 brings us 30 new elements to mark up documents and applications, boosting the total number of elements available to us to over 100.
Sexy yet hollow demos aside, even the most JavaScript-astic Web 2.0-alicious application will likely have textual content that needs to be marked up sensibly, so let’s look at some of the new elements to make sure that your next project is as semantic as it is interactive.
Further Reading on SmashingMag:
- Coding An HTML 5 Layout From Scratch
- HTML 5 Cheat Sheet (PDF)
- Learning to Love HTML5
- The Importance Of HTML5 Sectioning Elements
To keep this article from turning into a book, we won’t look at each in depth. Instead, this is a taster menu: you can see what’s available, and there are links that I’ve vetted for when you want to learn more.
Along the way, we’ll see that HTML5 semantics are carefully designed to extend the current capabilities of HTML, while always enabling users of older browsers to access the content. We’ll also see that semantic markup is not “nice to have,” but is rather a cornerstone of Web development, because it is what enhances accessibility, searchability, internationalization and interoperability.
A human language like English, with its vocabulary of a million words, can’t express every nuance of thought unambiguously, so with only 100 or so words that we can use in HTML, there will be situations when it’s not clear-cut which element to use for which piece of content. In that case, choose one; be consistent across the site.
Some Presentational Elements Are Gone
Purely presentational elements such as center
, font
and big
are now obsolete. Their role has been perfectly usurped by Cascading Style Sheets. Now, this doesn’t mean you have to rush out and recode all of those ancient pages; HTML5 makes them obsolete for authors, but because HTML5 strives not to break the Web, browsers will still render those cobwebbed legacy pages.
For the same reason, presentational attributes have been removed from current elements; for example, align
on img
, table
, background
on body
, and bgcolor
on table
.
The evil frame
element is absent in HTML5. Frames caused usability and accessibility nasties. If you get the urge to use them, use an older DOCTYPE
so that your pages still validate.
Beyond this short overview, see the W3C’s exhaustive list of removed elements and attributes.
Some Presentational Elements Have Been Redefined To Be Semantic
Not all presentational elements have been taken out and shot. Some have undergone an extensive re-education program and emerged with shiny new semantics. For example, the small
element no longer means “use a small font,” although it will display that way in browser style sheets. Now it represents side comments, such as small print:
Small print typically features disclaimers, caveats, legal restrictions, or copyrights. Small print is also sometimes used for attribution, or for satisfying licensing requirements.
Some of the redefinitions feel to me to be a mop-up. While I can get behind <b>
for drawing attention to product names, keywords and so forth, without any special emphasis implied, specifying the semantics for marking up ship names (<i>
, if you’re so inclined) feels weirdly precise. But I get seasick, and your nautical mileage may vary. With similar niche precision:
The u
element [now] represents a span of text with an unarticulated, though explicitly rendered, non-textual annotation, such as labeling the text as being a proper name in Chinese text (a Chinese proper name mark), or labeling the text as being misspelt.
You can read more about changed elements and attributes on the W3C website.
Sexy New Semantics
We all know about video
and audio
. And canvas
is particularly popular at the moment because it allows for 3-D graphics using webGL, so game designers can port their products to the Web. Like good ol’ img
, these semantics are embedded content, because they drag in content from another source — either a file, a data URI or JavaScript.
Unlike img
, however, they have opening and closing tags, allowing for fallbacks. Therefore, browsers that don’t support the new semantics can be fed some content: an image could be the fallback for a canvas, for example, or a Flash movie could be the fallback for video
, a technique called “video for everybody.”
The source
and track
elements are empty elements (with no closing tags) that are children of video
or audio
.
The source
element gets past the codec Tower of Babel that we have. Each element points to a different source file (WebM, MP4, Ogg Theora), and the browser will play the first one it knows how to deal with:
<audio controls>
<source src=bieber.ogg type=audio/ogg>
<source src=bieber.mp3 type=audio/mp3>
<!-- fallback content: -->
Download <a href=bieber.ogg>Ogg</a> or <a href=bieber.mp3>MP3</a> formats.
</audio>
In this example, Opera, Firefox and Chrome will download the Ogg version of Master Bieber’s latest toe-tappin’ masterpiece, while Safari and IE will grab the MP3 version. Chrome can play both Ogg and MP3, but browsers will download the first source file that they understand. The fallback content between the opening and closing tags is a link to download the content to the desktop and play it via a separate media player, and it is only shown in browsers that can’t play native multimedia.
For video, you could use an embedded Flash movie hosted on YouTube:
<video controls>
<source src=best-video-ever.webm type=video/webm>
<source src=best-video-ever.mp4 type=video/mp4>
<!-- fallback content: -->
<iframe width="480" height="360"
src="http://www.youtube.com/embed/xzMUyqmaqcw?rel=0"
frameborder="0" allowfullscreen>
</iframe>
</video>
This way, users of older browsers, such as IE 6-8, will see a YouTube movie (as long as they have the Flash Player), so they will at least be able to see the video, while users with modern browsers will get the full native-video experience. Everyone gets the content, then, which is what your website is there for, after all.
The track
element is a newer addition to the HTML5 family and is being implemented by Opera, Chrome and IE at the moment. It points to a subtitle file that contains text and timing information. When implemented, it synchronizes captions with the media file to enable on-demand subtitling and captioning; useful not only for viewers who are hard of hearing, but also for those who do not speak the language used in the audio or video file.
Semantics For Internationalization
Less woo! than the semantics for multimedia and games are the semantics for internationalization. It may surprise the cool kids in Silicon Valley to learn that a worldwide Web of people use languages other than English and even use different writing systems.
Languages such as Arabic and Hebrew are written right to left, unlike European languages, which are written left to right. On pages that use only one writing system, this doesn’t present a problem, but on pages with bi-directional (“bidi”) writing, browsers have to decide where to put punctuation, bullets, numbers and the like. Browsers usually do a pretty good job using the Unicode bidirectional algorithm, but it gets it wrong in some cases, which can seriously dent the comprehensibility of content.
HTML5 gives us a bdi
element, which enables authors to override the Unicode bidirectional algorithm and make their text more comprehensible. For a further description of the problem and to see how bdi
solves it, see “HTML5’s New bdi
Element” by Richard Ishida, the W3C’s internationalization activity lead.
Some languages have scripts that are not alphabetic at all, but that express an idea rather than a sound. Occasionally, an author will have to assist readers with pronunciation for especially rare or awkward characters, usually by providing an alternate script in a small font above the relevant character. In print, this was traditionally done with a very small 5-point font called “ruby,” and HTML5 gives us three new elements for marking up ruby text: ruby
, rt
and rp
.
For more information, see “The HTML5 ruby
Element in Words of One Syllable or Less” by Daniel Davis.
Structural Semantics
Most people are aware that HTML5 gives us many new elements to describe parts of a Web page, such as header
, footer
, nav
, section
, article
, aside
and so on. These exist because we Web developers actually wanted such semantics. How did the authors of the HTML5 specification know this? Because in 2005 Google analyzed 1 billion pages to see what authors were using as class names on div
s and other elements. More recently, in 2008, Opera MAMA analyzed 3 million URLs to see the top class names and top IDs used in the wild. These analyses revealed that authors wanted to mark up these areas of the page but had no elements to do so, other than the humble and generic div
, to which they then added descriptive classes and IDs.
(HTML5 Doctor has many articles about HTML5 semantics, so we won’t bloat this article by going in depth here. Warning: some were written by me.)
The new semantics were built to degrade gracefully. For example, consider what the specification has to say about the new figure
element:
Thefigure
element represents some flow content, optionally with a caption, that is self-contained and is typically referenced as a single unit from the main flow of the document.The element can thus be used to annotate illustrations, diagrams, photos, code listings, etc…
This isn’t a new idea. HTML3 proposed a fig
element (which never made it into the final HTML 3.2 specification). It looked like this:
<FIG SRC="nicodamus.jpeg">
<CAPTION>Ground dweller: <I>Nicodamus bicolor</I> builds silk snares</CAPTION>
<P>A small hairy spider.
<CREDIT>J. A. L. Cooke/OSF</CREDIT></P>
</FIG>
There’s a big problem with this. In browsers that do not support fig
(and none do), the image wouldn’t be displayed because the fig
element would be completely ignored. The contents of the credit
element would be displayed, because it’s just text. So you’d get a credit with no image on older browsers.
In HTML5, you would code the same example like so:
<figure>
<img src="nicodamus.jpeg">
<figcaption>
<p>Ground dweller: <i>Nicodamus bicolor</i> builds silk snares.</p>
<p>A small hairy spider.
<small>J. A. L. Cooke/OSF</small></p>
</figcaption>
</figure>
Unlike the aborted HTML3 syntax, the HTML5 version is backwards-compatible: a browser that doesn’t “know” about the figure
element will still show the img
and the text inside figcaption
(as the HTML3 credit
element would similarly display its content). Note that we’re using the redefined small
element, instead of minting a new credit
element. Remember that “Small print is also sometimes used for attribution.”
HTML5 also gives us a new figcaption
element. Originally, the specification’s authors tried to reuse caption
, as suggested in HTML3, but there were legacy problems, because caption
had previously only been a child of table
.
One of the design principles on which HTML5 is based is that new features should degrade gracefully. When they can’t, the language allows for fallback content. It tries to reuse elements rather than mint new ones — but it’s a pragmatic language: when minting something new is necessary, it does so.
Interactive Semantics
The structural elements of HTML5 currently don’t do much in visual browsers, although software that sits on top of browsers (such as screen readers) are starting to use them (see “HTML5, ARIA Roles, and Screen Readers in March 2011“ and “JAWS, IE and Headings in HTML5.”)
Other elements do have a visual effect. The details
element, for example, is a groovy interactive element that functions as “a disclosure widget from which the user can obtain additional information or controls.”
Most browsers will implement it as an “expando box”: when the user clicks on some browser-generated icon (such as a triangle or downwards-pointing arrow) or the word “Details” (which can be replaced by the author’s own rubric in a child summary
), the element will slide open, revealing its details within. The details could be a full description of an image or graph, a description of a complex table, advanced options for a search form, or just about anything else. This is a common need on the Web today, now made native and obviating the need for custom JavaScript.
Most of us have seen HTML5’s new form semantics. Most of these are attributes of the input
element, thereby ensuring graceful degradation to <input type=text>
in older browsers. New elements include datalist
, output
, progress
and meter
.
Do We Have The Right Semantics?
So, we have many new semantics, but are they the right ones? After all, the Google research on which they were based was conducted in 2005 — quite some time ago! Perhaps the semantics are already somewhat behind the times? Many have noted that they’re document-centric rather than application-centric. Do we need more application-centered semantics, such as a login
or share
element, or some kind of modal
element for modal dialogue boxes?
I don’t know; I’m not an app developer. But at least HTML is a “living standard,” and so these can be added if strong enough use cases are presented to the Working Group.
I think most coders would welcome a new way to embed images that respond to the device’s context. Borrowing from the video
element, which displays source video according to what media queries instruct, I can imagine a new element such as picture
:
<picture alt="angry pirate">
<source src=hires.png media="min-width:800px">
<source src=midres.png media="min-width:480px">
<source src=lores.png>
<!-- fallback for browsers without support -->
<img src=midres.png alt="angry pirate">
</picture>
This would pull in hires.png
for widescreen devices, midres.png
for devices between 480 and 800 pixels wide, and lores.png
for everything else, thereby rendering moot the question that designers currently ask themselves, “Do I make every browser download a high-resolution image and then squash it down for small screens, thus wasting bandwidth, or do I send a low-resolution image to every browser and scale it up for big screens, potentially sacrificing quality?”
Taking a leaf from the other popular semantics we’ve seen, there would be a fallback in the middle — in this case, a conventional img
element — so everyone would get the right content.
Sending the right-sized image to devices without wasting bandwidth is one of the knottiest problems in cross-device and responsive design at the moment. Perhaps we’ll see a solution to this in HTML6. At the moment, the best solutions, which include Matt Wilcox’s Adaptive Images and Filament Group’s Responsive Images, require JavaScript and tweaks to the server’s htaccess
file. The worst solutions require old-fashioned techniques, such as browser-sniffing, now rebranded as “device detection” but still the same old user-agent string-pattern matching, which is hilariously fragile, not future-proof or scalable, and straight out of the days of “Best viewed in Netscape Navigator at 800 × 600” badges on websites.
When, Where, Who?
A lot of data depends on three pieces of information: when, where and who?
HTML5 has a time
element (which has been a bit of a battleground lately). This enables you to annotate a human-readable date with an unambiguous machine-readable one. It doesn’t matter what goes between the tags, because that’s the content for people to read. So, you could use either of the following:
<time datetime="1982-07-18">The day the woman I love was born</time>
<time datetime="1982-07-18">Priyanka Chopra’s birthday</time>
Whichever you choose, the machine would still know the date you mean because of the datetime
attribute, formatted as YYYY-MM-DD
. If you wanted to add a time, you could: separate the time from the date with a T
, and then put the time in 24-hour format, terminated by a Z
, along with any time-zone offset. So, 2011-11-13T20:00Z
would be 8:00 pm on 13 November 2011 UTC, while 2011-11-13T23:26.083Z-05.00
would be 23:26 pm and 83 milliseconds in the time zone lying 5 hours before UTC. A Sri Lankan-localised browser could use this information to automatically convert dates into Buddhist calendar. Search engines could use timestamps to help evaluate “freshness”.
It’s perhaps surprising that, even though geolocation is so prevalent now, we don’t have a location element that simply takes three attributes: latitude, longitude and (optionally) altitude. It would be great to be able to write the following:
<location lat=51.502064 long=-0.131981>London SW1A 4WW</location>
The browser would then offer to show you a map or give you directions from the current GPS location or any other location-based service.
(Since I gave the talk that this article is based on, Ian Hickson, the HTML5 editor, said that he expects to add a new <geo> element. If I could choose, I’d prefer place
, so I could wear a T-shirt with the slogan “I’ve got the time
if you’ve got the place
”.)
HTML3 had a person
element, “used for names of people to allow these to be extracted automatically by indexing programs,” but it was never implemented. In HTML4, the cite
element could be used to wrap names of people, but this has been removed in HTML5 — controversially (see “Incite a Riot” by Jeremy Keith). In HTML5, then, we’re left with no way to unambiguously denote a person. People’s names are, however, a hard problem to solve. Whereas times and dates have well-known standardized ISO formats (YYYY-MM-DD
and HH:MM:SS.mmm
, respectively), and location is always latitude, longitude and altitude, personal names are harder to break down into useful parts: there are Russian patronymics, Indonesian single-word names, multiple family names, and Thai nicknames to consider. (See Richard Ishida’s excellent article “Personal Names Around the World” for more information and discussion.)
The new data
element, which replaces time
, has a value attribute that passes machine-readable information, but it has no required or implied format, so there is no way for a browser or search engine to know, for example, whether 1936-10-19
is a date, a part number or a postal code.
Microdata
HTML5, like HTML4, is extensible (but not in the oh-so-dirty eXtensibility way of XML formats, so loathed by the Working Group). You can use the tried and tested microformats, which use HTML classes, or the full RDFa specification, which doesn’t validate in HTML4 or HTML5. Because RDFa was considered to be too hard for authors to write (Google has conducted research that finds that authors make 30% more mistakes with RDFa than with other formats), HTML5 specifies microdata, a mechanism for adding common semantics via agreed-upon markup patterns. HTML5 Doctor has more information on HTML5 microdata, and Opera 11.60 supports the Microdata DOM API.
Like microformats and RDFa, the extra semantics added to the markup make sense only if you have a cheat sheet that tells you what each piece means. This means that the data has to point to a vocabulary that tells any crawler how to interpret the lump of data it finds. For microdata, there is the newly established Schema.org, which is “a collection of schemas, i.e. HTML tags, that webmasters can use to mark up their pages in ways recognized by major search providers.”
Do Semantics Matter Anyway?
Now that more and more markup is generated by JavaScript, some people are tempted to think that semantics don’t matter. We see various products marketed as HTML5 which simply make div
s fly around the screen with JavaScript — simple DHTML techniques unchanged from 10 years ago.
I’ve even seen some Web pages with no markup at all. Some frameworks emit skeletal HTML with empty body
tags and inject all the HTML with script. If you’re squirting some minified JavaScript down the wire, with no markup at all, you’re closer to Flash than you are to the Web.
In the same way that 47 minutes is (apparently) too long to to struggle making a CSS layout, at which point you should just give up and use tables, some people suggest that thinking about which element to use is a waste of time. “There are two types of developers: those who argue about div’s not being semantic and those who create epic shit” writes Thomas Fuchs, as if the two activities were mutually exclusive.
A better argument is that no software cares about or consumes semantics anyway, so why bother? This isn’t true (work is underway already to map assistive technologies to new semantics), but even if it were true, it ignores that this is a chicken-and-egg argument. It assumes that no new search engine will ever come to the market and be able to use new elements, or that browsers will never release new versions that can make use of these semantics, and that developers will write no new extensions — in short, it assumes that the evolution of the Web is complete.
Semantics do matter. Semantics communicate meaning, and once that is established, machines can do something meaningful with that data, without having to develop and use algorithms to guess. A browser extension might allow a user to jump straight to the nav
with a single keystroke. It can do this because it looks for nav
rather than having to employ heuristics to find a div
with an id
or class
that would suggest it’s being used as navigation (assuming the author decided to use something sensible like nav, navigation, sidebar, or menu — and a restaurant site with a div
called “menu” might be a list of foods rather than other pages…ah, the ambiguity of natural language). A crawler might dynamically assemble articles on a timeline. There are many more possibilities than my meagre imagination can dream up.
The Web is based on simple technologies, mashed up together to bring surprising results — results which have certainly surpassed the inventors’ original intents or expectations. The Web will continue to do so. What makes the Web so great, so flexible and so powerful is the fact that content is in open formats that can be parsed and mashed up in new and surprising ways.
These can happen if the content is marked up for meaning by the author — and if the language has the right markup elements for authors to use as a vocabulary. HTML5 extends our vocabulary. We’ll need more words — and those will come about with HTML6 etc.
If, like me, you believe the Web to be a system that works across browsers, across operating systems, across devices, across languages, that is View-sourcable, hackable, mash-uppable, accessible, indexable, reusable, then we need to ensure that we use the small number of semantic tools at our disposal properly, and we’ll all benefit.
(This article is based on a talk I gave at the Fronteers Conference.)
About the Author
Bruce evangelizes Open Web Standards for Opera. He wrote the book Introducing HTML5 together with Remy Sharp. The book points out the good and bad parts of HTML5 specifications and shows you how to use the language as well as some areas of spec will be discussed theoretically as they’re not yet implemented anywhere. It’s the first full-length book on HTML5 (New Riders, appearing in the 2nd edition).
(al) (il) (vf)