Published at
Updated at
Reading time
1min
This post is part of my Today I learned series in which I share all my web development learnings.

I'm sitting at the airport in Bangkok right now (yeah vacation!!!) and am reading an article by Adrian Roselli on tables regarding accessibility.

It can not be that hard to build an accessible table. It's just the table element including other th, tr and td elements, right?

Not quite... The article goes into beautiful detail on what it means to build an accessible table, and in the first few paragraphs of it, it already included something that was new to me – the caption element in tables.

<table>
  <caption>Populations of cities</caption>
  <thead>
    <tr>
      <th>City</th>
      <th>Population</th>
    </tr>
  </thead>
  <tr>
    <!-- ... -->
  </tr>
</table>   

caption is one element you don't see "in the wild" very often. The spec defines it as follows:

[...] the first element child of a table element.

The caption element represents the title of the table that is its parent, if it has a parent and that is a table element.

Defining a title and some additional information for a table makes total sense to me, and more surprising than its rare usage is only that the caption element even has its own mention in the techniques for WCAG 2.0. 😲

That said, my next table definitely includes a caption element.

Edited: As Eric Eggert pointed out there also other ways to label a table.

Was this TIL post helpful?
Yes? Cool! You might want to check out Web Weekly for more quick learnings. The last edition went out 24 days ago.

Related Topics

Related Articles

About the author

Stefan standing in the park in front of a green background

Frontend nerd with over ten years of experience, "Today I Learned" blogger, conference speaker, Tiny helpers maintainer, and DevRel at Checkly.