On The <dl> (2021)

ravenical 376 points 110 comments May 23, 2026
benmyers.dev · View on Hacker News

Discussion Highlights (19 comments)

turtleyacht

Hoped to see CSS for the alternative, where <div> is not nested inside the <dl>. Too used to thinking of div as "layout containers."

Telemakhos

I was a bit surprised to see nested <div>s given as some sort of precursor pattern, when <dl> was part of HTML before 2.0 back in the days of table layout.

rickstanley

I've used this a good amount of times, when I coded in front end projects. The first time gave me that satisfying feeling of using the right tool for the job, like completing a puzzle of HTML semantics. I remember JAWS not announcing it correctly in 2018, not sure if it's better now.

phyzix5761

I'm curious if the spec actually says you can only wrap it with a div because I like to do semantic html and name my elements specific to my domain.

captn3m0

> Prior to HTML5, this was called a definition list. This is because the <dl> was originally only intended to represent glossaries of terms and their definitions. TIL I’ve been naming it wrong for a decade.

cloud-oak

The final example of the DnD statt sheet makes me think whether it's legal to nest <dl>s? I.e. can we do <dl> <dt>Actions</dt> <dd><dl>...</dl></dd> </dl>

jdw64

blog looks beautiful. I really wish I had this kind of talent for frontend.

michalc

The GOV.UK Design System summary list component is a description list https://design-system.service.gov.uk/components/summary-list... And... it also uses the wrapper div for styling

gbeardish

What about multiple '<dt>' for one or more '<dd>'?

simonw

Here's a useful note on how well screen readers support DL: https://adrianroselli.com/2025/01/updated-brief-note-on-desc...

Demiurge

I love DL. I think tables, at least in the past, were misused as DLs even more in the past and the inconvenience of the table markup is even worse than a bunch of divs.

mockbuild

it's on archive html5 .flac 16-bit 44.1kHz no <dl> flag.

tln

> Admittedly, however, support for the <dl> element is not yet universal. Wait what? <DL> has been in HTML since.. the first draft in 1993! I like DL's but they can be challenging to style. This article is using a lot of fixed pixel widths which would break on really small screens or larger data.

smitty1e

This seems a clear enough win for things that would fit into a simple python dictionary. Why is it preferred over <table> for laying out columns via a the character attributes at the bottom of TFA?

jimbosis

The world's first website makes heavy use of <dl>s. https://info.cern.ch/hypertext/WWW/TheProject.html https://info.cern.ch/ (A landing page of sorts to give context and orientation about the actual first website.)

chrismorgan

> <dl aria-label="Ability Scores"> This is incorrect: 1. <dl> has no corresponding ( viz. implicit) role, but can be given the role group, list, none or presentation < https://w3c.github.io/html-aria/#el-dl >. 2. You’re only allowed to define aria-label on elements that have a compatible role, implicit or explicit < https://w3c.github.io/html-aria/#docconformance-naming >. 3. aria-label is allowed on all but a handful of roles < https://www.w3.org/TR/wai-aria-1.2/#aria-label >, which in this case knocks out presentation and none, leaving group and list. 4. group doesn’t feel right, list feels acceptable. In summary: either ditch the aria-label, or add role="list" (meaning also role="listitem" on children). —⁂— One thing the article misses is that you can have multiple <dt> in a row too, not just <dd>. The spec has a good example: https://html.spec.whatwg.org/multipage/grouping-content.html... They’re not name–value pairs , they’re name–value groups .

shermantanktop

The <dl> tag seems to cover a subset of a broad semantic space, but doesn’t easily extend beyond adding another <dd>. I dunno, I guess I’m a caveman. If it looks right and works (including accessibility) then I figure I’m pursuing something that doesn’t matter a lot.

Finnucane

We've always used this in our ebooks for abbreviation and glossary lists. The problem I've always had is that you need to use a bit of css to make two lined-up columns. I've done it with floats. Now, some ebook readers will support grid and flex-box, which give better results, but the Kindle still does not. Kindle is sort of the IE6 of the ebook world.

kqp

This is going to be unpopular here, but life became easier when I quit trying to write semantic HTML. It’s just poorly designed, I’m sorry. Every time I’ve reached for a <dl> I’ve eventually regretted it because I wanted multiple levels of wrappers, or a divider between sections, or an icon, or a heading spanning multiple key-value pairs, etc. They make this stuff with some flexibility but nowhere near enough to actually cover the generalized concept it purports to. I still use the corresponding elements when there are observable benefits, of course, like <button>, <h1>, etc, but when all it’s going to do is not quite fit the data model and force me to override everything, it’s just not a practical choice. It shouldn’t be so controversial to say that if 99% of usage routes around your API, it’s probably the API’s fault.

Semantic search powered by Rivestack pgvector
8,303 stories · 78,303 chunks indexed