Skip to content

elseIfDuplicates

Reports duplicate conditions in if-else-if chains that make code unreachable.

✅ This rule is included in the ts logical preset.

When an if-else-if chain contains duplicate conditions, the branch with the duplicate condition will never execute. This is because the earlier identical condition will always be evaluated first and match when true, preventing the duplicate condition from ever being reached. Duplicate conditions typically indicate a copy-paste error or a logic mistake in the code.

if (status === "pending") {
handlePending();
} else if (status === "active") {
handleActive();
} else if (status === "pending") {
handlePendingAgain();
}
if (isValid && isActive) {
processValid();
} else if (isPending) {
processPending();
} else if (isValid && isActive) {
processValidAgain();
}
if (count === 1) {
handleOne();
} else if (count === 2) {
handleTwo();
} else if (count === 1) {
handleOneAgain();
}

This rule is not configurable.

If your project intentionally uses patterns that look like duplicate conditions but actually modify state behind-the-scenes, you might not want to enable this rule. For example, projects that modify state in computed object get() properties or use Proxy are often considered overly difficult to reason about for both humans and lint rules.

Made with ❤️‍🔥 in Boston by Josh Goldberg and contributors.