🔧 This rule is automatically fixable by the --fix
CLI option.
A fragment is redundant if it contains only one child, or if it is the child of a html element, and is not a keyed fragment.
Examples of incorrect code for this rule:
<>{foo}</>
<><Foo /></>
<p><>foo</></p>
<></>
<Fragment>foo</Fragment>
<Inferno.Fragment>foo</Inferno.Fragment>
<section>
<>
<div />
<div />
</>
</section>
{showFullName ? <>{fullName}</> : <>{firstName}</>}
Examples of correct code for this rule:
{foo}
<Foo />
<>
<Foo />
<Bar />
</>
<>foo {bar}</>
<> {foo}</>
const cat = <>meow</>
<SomeComponent>
<>
<div />
<div />
</>
</SomeComponent>
<Fragment key={item.id}>{item.value}</Fragment>
{showFullName ? fullName : firstName}
When true
single expressions in a fragment will be allowed. This is useful in
places like Typescript where string
does not satisfy the expected return type
of JSX.Element
. A common workaround is to wrap the variable holding a string
in a fragment and expression.
Examples of correct code for the rule, when "allowExpressions"
is true
:
<>{foo}</>
<>
{foo}
</>