useSortedAttributes
Este conteúdo não está disponível em sua língua ainda.
Summary
Section titled “Summary”- Rule available since: v2.0.0
- Diagnostic Category: assist/source/useSortedAttributes
- The default severity of this rule is information.
- Sources:
- Same as react/jsx-sort-props
 
- Same as 
How to enable in your editor
Section titled “How to enable in your editor”{  "editor.codeActionsOnSave": {    "source.action.useSortedAttributes.biome": "explicit",    "source.fixAll.biome": "explicit"  }}{  "code_actions_on_format": {    "source.action.useSortedAttributes.biome": true,    "source.fixAll.biome": true  }}source.action.useSortedAttributes.biome  How to configure
Section titled “How to configure”{  "assist": {    "actions": {      "source": {        "useSortedAttributes": "on"      }    }  }}Description
Section titled “Description”Enforce attribute sorting in JSX elements.
This rule checks if the JSX props are sorted in a consistent way. Props are sorted alphabetically using a natural sort order. This rule will not consider spread props as sortable. Instead, whenever it encounters a spread prop, it will sort all the previous non spread props up until the nearest spread prop, if one exist. This prevents breaking the override of certain props using spread props.
Examples
Section titled “Examples”<Hello lastName="Smith" firstName="John" />;code-block.jsx ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ℹ Source action diff:
  
    1   │ - <Hello·lastName=“Smith”·firstName=“John”·/>;
      1 │ + <Hello·firstName=“John”·lastName=“Smith”·/>;
    2 2 │   
  
<Hello lastName="Smith" firstName="John" {...this.props} tel="0000" address="111 Main Street"  {...another.props} lastName="Smith" />;code-block.jsx ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ℹ Source action diff:
  
    1   │ - <Hello·lastName=“Smith”·firstName=“John”·{...this.props}·tel=“0000”·address=“111·Main·Street”··{...another.props}·lastName=“Smith”·/>;
      1 │ + <Hello·firstName=“John”·lastName=“Smith”·{...this.props}·tel=“0000”·address=“111·Main·Street”··{...another.props}·lastName=“Smith”·/>;
    2 2 │   
  
code-block.jsx ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ℹ Source action diff:
  
    1   │ - <Hello·lastName=“Smith”·firstName=“John”·{...this.props}·tel=“0000”·address=“111·Main·Street”··{...another.props}·lastName=“Smith”·/>;
      1 │ + <Hello·lastName=“Smith”·firstName=“John”·{...this.props}·address=“111·Main·Street”·tel=“0000”··{...another.props}·lastName=“Smith”·/>;
    2 2 │   
  
Options
Section titled “Options”This actions accepts following options
sortOrder
Section titled “sortOrder”This options supports natural and lexicographic values. Where as natural is the default.
Following will apply the natural sort order.
{  "assist": {    "actions": {      "source": {        "useSortedAttributes": {          "options": {            "sortOrder": "natural"          }        }      }    }  }}<Hello tel={5555555} {...this.props} opt1="John" opt2="" opt12="" opt11="" />;code-block.jsx:1:1 assist/source/useSortedAttributes  FIXABLE  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ℹ The attributes are not sorted. 
  
  > 1 │ <Hello tel={5555555} {…this.props} opt1=“John” opt2="" opt12="" opt11="" />;
      │ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    2 │ 
  
  ℹ Safe fix: Sort the JSX props.
  
    1   │ - <Hello·tel={5555555}·{...this.props}·opt1=“John”·opt2=""·opt12=""·opt11=""·/>;
      1 │ + <Hello·tel={5555555}·{...this.props}·opt1=“John”·opt2=""·opt11=""·opt12=""·/>;
    2 2 │   
  
Following will apply the lexicographic sort order.
{  "assist": {    "actions": {      "source": {        "useSortedAttributes": {          "options": {            "sortOrder": "lexicographic"          }        }      }    }  }}<Hello tel={5555555} {...this.props} opt1="John" opt2="" opt12="" opt11="" />;code-block.jsx:1:1 assist/source/useSortedAttributes  FIXABLE  ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
  ℹ The attributes are not sorted. 
  
  > 1 │ <Hello tel={5555555} {…this.props} opt1=“John” opt2="" opt12="" opt11="" />;
      │ ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    2 │ 
  
  ℹ Safe fix: Sort the JSX props.
  
    1   │ - <Hello·tel={5555555}·{...this.props}·opt1=“John”·opt2=""·opt12=""·opt11=""·/>;
      1 │ + <Hello·tel={5555555}·{...this.props}·opt1=“John”·opt2=""·opt11=""·opt12=""·/>;
    2 2 │   
  
Copyright (c) 2023-present Biome Developers and Contributors.