home / skills / benchflow-ai / skillsbench / web-interface-guidelines
/tasks/fix-visual-stability/environment/skills/web-interface-guidelines
This skill reviews UI components against Vercel's web interface guidelines to improve accessibility, performance, and visual stability.
npx playbooks add skill benchflow-ai/skillsbench --skill web-interface-guidelinesReview the files below or copy the command above to add this skill to your agents.
---
name: web-interface-guidelines
description: Vercel's comprehensive UI guidelines for building accessible, performant web interfaces. Use this skill when reviewing or building UI components for compliance with best practices around accessibility, performance, animations, and visual stability.
---
# Web Interface Guidelines
Review UI code for compliance with Vercel's web interface standards.
## Quick Reference - Visual Stability
| Issue | Rule |
|-------|------|
| Images without dimensions | `<img>` needs explicit `width` and `height` (prevents CLS) |
| Font loading flash | Critical fonts: `<link rel="preload" as="font">` with `font-display: swap` |
| Large lists | Virtualize lists >50 items (`content-visibility: auto`) |
| Layout reads in render | No `getBoundingClientRect`, `offsetHeight` in render path |
## Full Rules
### Images
- `<img>` needs explicit `width` and `height` (prevents CLS)
- Below-fold images: `loading="lazy"`
- Above-fold critical images: `priority` or `fetchpriority="high"`
### Performance
- Large lists (>50 items): virtualize (`virtua`, `content-visibility: auto`)
- No layout reads in render (`getBoundingClientRect`, `offsetHeight`, `offsetWidth`, `scrollTop`)
- Batch DOM reads/writes; avoid interleaving
- Add `<link rel="preconnect">` for CDN/asset domains
- Critical fonts: `<link rel="preload" as="font">` with `font-display: swap`
### Accessibility
- Icon-only buttons need `aria-label`
- Form controls need `<label>` or `aria-label`
- Interactive elements need keyboard handlers (`onKeyDown`/`onKeyUp`)
- `<button>` for actions, `<a>`/`<Link>` for navigation (not `<div onClick>`)
- Images need `alt` (or `alt=""` if decorative)
### Focus States
- Interactive elements need visible focus: `focus-visible:ring-*` or equivalent
- Never `outline-none` / `outline: none` without focus replacement
- Use `:focus-visible` over `:focus` (avoid focus ring on click)
### Animation
- Honor `prefers-reduced-motion` (provide reduced variant or disable)
- Animate `transform`/`opacity` only (compositor-friendly)
- Never `transition: all`—list properties explicitly
### Forms
- Inputs need `autocomplete` and meaningful `name`
- Use correct `type` (`email`, `tel`, `url`, `number`) and `inputmode`
- Never block paste (`onPaste` + `preventDefault`)
- Labels clickable (`htmlFor` or wrapping control)
### Content Handling
- Text containers handle long content: `truncate`, `line-clamp-*`, or `break-words`
- Flex children need `min-w-0` to allow text truncation
- Handle empty states—don't render broken UI for empty strings/arrays
### Anti-patterns (flag these)
- `user-scalable=no` or `maximum-scale=1` disabling zoom
- `transition: all`
- `outline-none` without focus-visible replacement
- Images without dimensions
- Large arrays `.map()` without virtualization
- Form inputs without labels
- Icon buttons without `aria-label`
This skill provides Vercel-aligned UI guidelines to review and build accessible, performant, and visually stable web interfaces. It focuses on practical checks for images, fonts, lists, animations, forms, and focus behavior. Use it to flag common anti-patterns and enforce pragmatic best practices.
The skill inspects component code and markup for common issues: missing image dimensions, improper font preloading, layout reads during render, and missing accessibility attributes. It also evaluates performance patterns like large un-virtualized lists, improper animations, and DOM read/write interleaving. The output highlights violations, explains impact (CLS, keyboard accessibility, jank), and recommends concrete fixes.
What counts as a critical image vs below-fold?
Critical images are visible on initial load or above the fold; they should be prioritized (priority or fetchpriority="high"). Below-fold images can use loading="lazy".
How do I handle decorative images?
Use alt="" for purely decorative images so assistive tech ignores them, while meaningful images need descriptive alt text.