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

Commit 21634e6

Browse files
authored
docs: Adapt a11y skill to utilize Lighthouse (#1054)
- **feat: Add Lighthouse audit as the initial step in the accessibility debugging workflow and reorder subsequent sections.** - **feat: Add critical instructions for parsing Lighthouse audit reports to efficiently extract failing elements.**
1 parent 13a18e2 commit 21634e6

File tree

1 file changed

+26
-8
lines changed

1 file changed

+26
-8
lines changed

skills/a11y-debugging/SKILL.md

Lines changed: 26 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -11,16 +11,34 @@ description: Uses Chrome DevTools MCP for accessibility (a11y) debugging and aud
1111

1212
## Workflow Patterns
1313

14-
### 1. Browser Issues & Audits
14+
### 1. Automated Audit (Lighthouse)
1515

16-
Chrome automatically checks for common accessibility problems. Use `list_console_messages` to check for these native audits first:
16+
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.
17+
18+
1. Run the audit:
19+
- Set `mode` to `"navigation"` to refresh the page and capture load issues.
20+
- Set `outputDirPath` (e.g., `/tmp/lh-report`) to save the full JSON report.
21+
2. **Analyze the Summary**:
22+
- Check `scores` (0-1 scale). A score < 1 indicates violations.
23+
- Review `audits.failed` count.
24+
3. **Review the Report (CRITICAL)**:
25+
- **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:
26+
```bash
27+
# Extract failing audits with their details
28+
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})))"
29+
```
30+
- This efficiently extracts the `selector` and `snippet` of failing elements without loading the full report into context.
31+
32+
### 2. Browser Issues & Audits
33+
34+
Chrome automatically checks for common accessibility problems. Use `list_console_messages` to check for these native audits:
1735

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

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

23-
### 2. Semantics & Structure
41+
### 3. Semantics & Structure
2442

2543
The accessibility tree exposes the heading hierarchy and semantic landmarks.
2644

@@ -29,7 +47,7 @@ The accessibility tree exposes the heading hierarchy and semantic landmarks.
2947
3. **Check Heading Levels**: Ensure heading levels (`h1`, `h2`, `h3`, etc.) are logical and do not skip levels. The snapshot will include heading roles.
3048
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.
3149

32-
### 3. Labels, Forms & Text Alternatives
50+
### 4. Labels, Forms & Text Alternatives
3351

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

5674
4. Check images for `alt` text.
5775

58-
### 4. Focus & Keyboard Navigation
76+
### 5. Focus & Keyboard Navigation
5977

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

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

67-
### 5. Tap Targets and Visuals
85+
### 6. Tap Targets and Visuals
6886

6987
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`:
7088
@@ -78,7 +96,7 @@ el => {
7896
7997
_Pass the element's `uid` from the snapshot as an argument to `evaluate_script`._
8098

81-
### 6. Color Contrast
99+
### 7. Color Contrast
82100

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

@@ -124,7 +142,7 @@ el => {
124142
125143
_Pass the element's `uid` to test the contrast against WCAG AA (4.5:1 for normal text, 3:1 for large text)._
126144
127-
### 7. Global Page Checks
145+
### 8. Global Page Checks
128146
129147
Verify document-level accessibility settings often missed in component testing:
130148

0 commit comments

Comments
 (0)