Skip to content

useUniqueElementIds

biome.json
{
"linter": {
"rules": {
"correctness": {
"useUniqueElementIds": "error"
}
}
}
}

Prevent the usage of static string literal id attribute on elements.

In React, hardcoding IDs is discouraged because IDs have to be unique in the DOM. You should use useId to generate unique IDs for accessibility purposes.

Please keep in mind this rule doesn’t check whether ids are actually unique or not, and does check whether static literal id isn’t passed to the elements or not. So you’re encouraged to check by yourself if the ids are actually unique.

<div id="foo">bar</div>;
<pre class="language-text"><code class="language-text">code-block.jsx:1:1 <a href="https://biomejs.dev/linter/rules/use-unique-element-ids">lint/correctness/useUniqueElementIds</a> ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━<br /><br /> <strong><span style="color: Tomato;"></span></strong> <span style="color: Tomato;"><strong>id</strong></span><span style="color: Tomato;"> attribute should not be a static string literal. Generate unique IDs using </span><span style="color: Tomato;"><strong>useId()</strong></span><span style="color: Tomato;">.</span><br /> <br /> <strong><span style="color: Tomato;">&gt;</span></strong> <strong>1 │ </strong>&lt;div id=&quot;foo&quot;&gt;bar&lt;/div&gt;;<br /> <strong></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><br /> <strong>2 │ </strong><br /> <br /> <strong><span style="color: lightgreen;"></span></strong> <span style="color: lightgreen;">In React, if you hardcode IDs and use the component multiple times, it can lead to duplicate IDs in the DOM. Instead, generate unique IDs using </span><span style="color: lightgreen;"><strong>useId()</strong></span><span style="color: lightgreen;">.</span><br /> <br /></code></pre>
React.createElement("div", { id: "foo" });
<pre class="language-text"><code class="language-text">code-block.jsx:1:1 <a href="https://biomejs.dev/linter/rules/use-unique-element-ids">lint/correctness/useUniqueElementIds</a> ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━<br /><br /> <strong><span style="color: Tomato;"></span></strong> <span style="color: Tomato;"><strong>id</strong></span><span style="color: Tomato;"> attribute should not be a static string literal. Generate unique IDs using </span><span style="color: Tomato;"><strong>useId()</strong></span><span style="color: Tomato;">.</span><br /> <br /> <strong><span style="color: Tomato;">&gt;</span></strong> <strong>1 │ </strong>React.createElement(&quot;div&quot;, &#123; id: &quot;foo&quot; &#125;);<br /> <strong></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><strong><span style="color: Tomato;">^</span></strong><br /> <strong>2 │ </strong><br /> <br /> <strong><span style="color: lightgreen;"></span></strong> <span style="color: lightgreen;">In React, if you hardcode IDs and use the component multiple times, it can lead to duplicate IDs in the DOM. Instead, generate unique IDs using </span><span style="color: lightgreen;"><strong>useId()</strong></span><span style="color: lightgreen;">.</span><br /> <br /></code></pre>
const id = useId();
<div id={id}>bar</div>;
const id = useId();
React.createElement("div", { id });

The following option is available

List of unqualified component names to ignore. Use it to list components expecting an id attribute that does not represent a DOM element ID.

Default: empty list.

biome.json
{
"linter": {
"rules": {
"correctness": {
"useUniqueElementIds": {
"options": {
"excludedComponents": [
"FormattedMessage"
]
}
}
}
}
}
}
<FormattedMessage id="static" />
<Library.FormattedMessage id="static" />