Skip to content

Latest commit

 

History

History
83 lines (54 loc) · 1.45 KB

jsx-no-useless-fragment.md

File metadata and controls

83 lines (54 loc) · 1.45 KB

Disallow unnecessary fragments (inferno/jsx-no-useless-fragment)

🔧 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.

Rule Details

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}

Rule Options

allowExpressions

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}
</>