Using the HTML `<dfn>` Element to Define Terms: Improving Content Clarity and Accessibility

Learn how to use the HTML `<dfn>` (definition) element to semantically mark up defined terms in your documents. This tutorial explains its functionality, demonstrates its usage, and shows how to customize its appearance using CSS, enhancing both readability and accessibility for users and assistive technologies.



Using the HTML `<dfn>` Element to Define Terms

Understanding the `<dfn>` Element

The HTML `<dfn>` (definition) element is designed to mark up a term that is being defined within a document. This adds semantic meaning, improving readability and making your content more accessible. The `<dfn>` element itself doesn’t inherently change the appearance of the text, but browsers typically render it in italics. You can customize the styling using CSS (Cascading Style Sheets) if you want a specific look and feel. The defined term should be closely associated with its definition, ideally within the same paragraph or section.

Ways to Use the `<dfn>` Element

You can use the `<dfn>` element in several ways:

  1. Simple Definition: Wrap the term in the `<dfn>` tags. The definition follows in the same element or a nearby element.
  2. Example 1: Simple Definition
    
    <p><dfn>HTML</dfn> is a markup language.</p>
    
  3. Definition with `title` Attribute: Add a `title` attribute to provide a tooltip with the definition. This provides a more user-friendly way to define terms without cluttering the main text flow.
  4. Example 2: Definition with `title` Attribute
    
    <p>Learn more about <dfn title="HyperText Markup Language">HTML</dfn>.</p>
    
  5. Definition with Nested Element: Nest other elements within the `<dfn>` tags for more complex definitions.
  6. Example 3: Definition with Nested Element
    
    <p><dfn>HTML<br> <small>HyperText Markup Language</small></dfn> is a markup language.</p>
    
  7. Definition with ID and Cross-Referencing: Assign an ID to the `<dfn>` and use other elements (like `` tags) to cross-reference it. This is beneficial for longer documents. It avoids repeating long definitions and provides quick access to definitions.
  8. Example 4: Definition with ID and Cross-Referencing
    
    <p><dfn id="html">HTML</dfn> is a markup language.  <a href="#html">More on HTML</a></p>
    

Browser Support and Default Styling

The `<dfn>` element is supported by all major modern browsers. They usually render defined terms in italics.

Browser Support
Chrome Yes
Edge Yes
Firefox Yes
Opera Yes
Safari Yes

You can override the default italic styling with CSS.