# a11y/duplicate-ids

No duplicate id values in the document. Reglen a11y/duplicate-ids kører i page-scope med severity 'error' og indgår i tilgængelighed-domænet sammen med 7 andre kontrakter i frameworket.

## Hvorfor duplicate-ids findes

Duplicate ids make label[for], ARIA references and fragment links resolve nondeterministically — the browser picks the first, which may not be the intended element. On templated pages one duplicated component multiplies the bug across the whole site.

## Sådan håndhæves duplicate-ids

Reglen duplicate-ids evalueres på hver enkelt renderet HTML-side for sig, så et fund altid kan føres tilbage til én konkret side og én konkret rettelse i data eller template. Fejler en side, får agenten en finding, hvor fix-instruktionen for duplicate-ids er formuleret som en konkret arbejdsordre med filnavne og målbare krav — aldrig et vagt råd. Severity 'error' betyder at et brud på duplicate-ids fejler hele verifikationen med exit-kode 1, så hverken CI eller en agent kan skibe sitet før fundet er rettet.

## Test og fixtures

Som alle kontrakter i frameworket har a11y/duplicate-ids en mutant-test, der beviser at reglen fejler, når kravet brydes — en regel uden en fejlende test er ikke en regel. Golden-fixturet beviser omvendt, at en fuldt compliant side består duplicate-ids sammen med de øvrige 85 regler, og denne demoside er selv underlagt hele kontrakten.

## Relaterede regler

- [a11y/iframe-title](https://pseo.mikkelkrogsholm.dk/regler/a11y/iframe-title/)
- [a11y/no-autoplay-motion](https://pseo.mikkelkrogsholm.dk/regler/a11y/no-autoplay-motion/)
- [a11y/main-landmark](https://pseo.mikkelkrogsholm.dk/regler/a11y/main-landmark/)
