| name | comparison-table |
| description | Use when you need to compare features and options side-by-side. |
| metadata | {"id":"comparison-table","category":"data-display","pattern":"Comparison Table","source":"uxpatterns.dev","url":"https://uxpatterns.dev/patterns/data-display/comparison-table","sourcePath":"apps/web/content/patterns/data-display/comparison-table.mdx"} |
Comparison Table
Compare features and options side-by-side
What it solves
A Comparison Table pattern helps teams create a reliable way to line up options side by side so users can evaluate feature, price, or policy differences quickly. It is most useful when teams need plan and feature comparison.
Compared with adjacent patterns, this pattern should reduce friction without hiding the state, rules, or recovery paths people need to keep moving.
When to use
- Plan and feature comparison
- Vendor or tool evaluation
- Product selection
When to avoid
- Use a simpler view when users only need one or two values and not the full layout.
- Avoid this pattern when the task is creation or editing rather than interpretation.
- Do not force the same view onto mobile if another representation would be clearer.
Implementation workflow
- Confirm the pattern matches the problem and constraints before copying the example.
- Start from the anatomy and examples in
references/pattern.md, then choose the smallest viable variation.
- Apply accessibility, performance, and interaction guardrails before layering visual polish.
- Use the testing guidance to verify behavior across keyboard, screen reader, responsive, and failure scenarios.
Accessibility guardrails
Keyboard Interaction
Screen Reader Support
Visual Accessibility
Performance guardrails
- Measure the cost of rendering the default view before adding richer adornments such as nested actions, charts, or inline filters.
- Use pagination, windowing, or progressive disclosure when the layout would otherwise render too many items at once.
- Stabilize heights and placeholder geometry so loading and data refresh states do not cause large layout shifts.
Common mistakes
Choosing the layout before the task
The Problem:
Teams often pick a visually familiar pattern before confirming whether users need comparison, exploration, or scanning.
How to Fix It?
Start from the user task, then map the layout to comparison, chronology, hierarchy, or overview needs.
Ignoring non-happy states
The Problem:
A polished default view still feels broken when loading, empty, and error states are inconsistent.
How to Fix It?
Design the data lifecycle up front, including empty, partial, stale, and failed results.
Shipping a desktop-only density model
The Problem:
Large tables, dense dashboards, and heavy cards collapse quickly on small screens.
How to Fix It?
Define a mobile strategy such as stacked cards, progressive disclosure, or alternate summaries before implementation.
Related patterns
For full implementation detail, examples, and testing notes, see references/pattern.md.
Pattern page: https://uxpatterns.dev/patterns/data-display/comparison-table