豆豆友情提示:这是一个非官方 GitHub 代理镜像,主要用于网络测试或访问加速。请勿在此进行登录、注册或处理任何敏感信息。进行这些操作请务必访问官方网站 github.com。 Raw 内容也通过此代理提供。
Skip to content
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
34 changes: 26 additions & 8 deletions skills/a11y-debugging/SKILL.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,34 @@ description: Uses Chrome DevTools MCP for accessibility (a11y) debugging and aud

## Workflow Patterns

### 1. Browser Issues & Audits
### 1. Automated Audit (Lighthouse)

Chrome automatically checks for common accessibility problems. Use `list_console_messages` to check for these native audits first:
Start by running a Lighthouse accessibility audit to get a comprehensive baseline. This tool provides a high-level score and lists specific failing elements with remediation advice.

1. Run the audit:
- Set `mode` to `"navigation"` to refresh the page and capture load issues.
- Set `outputDirPath` (e.g., `/tmp/lh-report`) to save the full JSON report.
2. **Analyze the Summary**:
- Check `scores` (0-1 scale). A score < 1 indicates violations.
- Review `audits.failed` count.
3. **Review the Report (CRITICAL)**:
- **Parsing**: Do not read the entire file line-by-line. Use a CLI tool like `jq` or a Node.js one-liner to filter for failures:
```bash
# Extract failing audits with their details
node -e "const r=require('./report.json'); Object.values(r.audits).filter(a=>a.score!==null && a.score<1).forEach(a=>console.log(JSON.stringify({id:a.id, title:a.title, items:a.details?.items})))"
```
- This efficiently extracts the `selector` and `snippet` of failing elements without loading the full report into context.

### 2. Browser Issues & Audits

Chrome automatically checks for common accessibility problems. Use `list_console_messages` to check for these native audits:

- `types`: `["issue"]`
- `includePreservedMessages`: `true` (to catch issues that occurred during page load)

This often reveals missing labels, invalid ARIA attributes, and other critical errors without manual investigation.

### 2. Semantics & Structure
### 3. Semantics & Structure

The accessibility tree exposes the heading hierarchy and semantic landmarks.

Expand All @@ -29,7 +47,7 @@ The accessibility tree exposes the heading hierarchy and semantic landmarks.
3. **Check Heading Levels**: Ensure heading levels (`h1`, `h2`, `h3`, etc.) are logical and do not skip levels. The snapshot will include heading roles.
4. **Content Reordering**: Verify that the DOM order (which drives the accessibility tree) matches the visual reading order. Use `take_screenshot` to inspect the visual layout and compare it against the snapshot structure to catch CSS floats or absolute positioning that jumbles the logical flow.

### 3. Labels, Forms & Text Alternatives
### 4. Labels, Forms & Text Alternatives

1. Locate buttons, inputs, and images in the `take_snapshot` output.
2. Ensure interactive elements have an accessible name (e.g., a button should not just say `""` if it only contains an icon).
Expand All @@ -55,7 +73,7 @@ The accessibility tree exposes the heading hierarchy and semantic landmarks.

4. Check images for `alt` text.

### 4. Focus & Keyboard Navigation
### 5. Focus & Keyboard Navigation

Testing "keyboard traps" and proper focus management without visual feedback relies on tracking the focused element.

Expand All @@ -64,7 +82,7 @@ Testing "keyboard traps" and proper focus management without visual feedback rel
3. Locate the element marked as focused in the snapshot to verify focus moved to the expected interactive element.
4. If a modal opens, focus must move into the modal and "trap" within it until closed.

### 5. Tap Targets and Visuals
### 6. Tap Targets and Visuals

According to web.dev, tap targets should be at least 48x48 pixels with sufficient spacing. Since the accessibility tree doesn't show sizes, use `evaluate_script`:

Expand All @@ -78,7 +96,7 @@ el => {

_Pass the element's `uid` from the snapshot as an argument to `evaluate_script`._

### 6. Color Contrast
### 7. Color Contrast

To verify color contrast ratios, start by checking for native accessibility issues:

Expand Down Expand Up @@ -124,7 +142,7 @@ el => {

_Pass the element's `uid` to test the contrast against WCAG AA (4.5:1 for normal text, 3:1 for large text)._

### 7. Global Page Checks
### 8. Global Page Checks

Verify document-level accessibility settings often missed in component testing:

Expand Down