Skip to content

unnecessaryFragments

Disallow unnecessary JSX fragments that wrap a single child or have no children.

✅ This rule is included in the jsx stylistic preset.

JSX fragments (<>...</> or <Fragment>...</Fragment>) are used to group multiple elements without adding extra nodes to the DOM. However, when a fragment wraps only a single child or has no children at all, it serves no purpose and adds unnecessary complexity to the code.

const element = (
<>
<div>Hello</div>
</>
);
const element = <>Hello</>;
const element = <></>;
const element = (
<Fragment>
<div>Hello</div>
</Fragment>
);

This rule is not configurable.

If your codebase has specific requirements where fragments are used consistently for stylistic reasons, you may want to disable this rule. However, removing unnecessary fragments is generally recommended to keep code concise and maintainable.

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