# react/jsx-tag-spacing 📝 Enforce whitespace in and around the JSX opening and closing brackets. 🔧 This rule is automatically fixable by the [`--fix` CLI option](https://eslint.org/docs/latest/user-guide/command-line-interface#--fix). Enforce or forbid spaces after the opening bracket, before the closing bracket, before the closing bracket of self-closing elements, and between the angle bracket and slash of JSX closing or self-closing elements. ## Rule Details This rule checks the whitespace inside and surrounding the JSX syntactic elements. ## Rule Options This rule takes one argument, an object with 4 possible keys: `closingSlash`, `beforeSelfClosing`, `afterOpening`, and `beforeClosing`. Each key can receive the value `"allow"` to disable that specific check. The default values are: ```json { "closingSlash": "never", "beforeSelfClosing": "always", "afterOpening": "never", "beforeClosing": "allow" } ``` The options for each sub-option are documented in the following subsections. ### `closingSlash` This check can be set to `"always"`, `"never"` or `"allow"` (to disable it). If it is `"never"`, the check warns whenever a space is separating the two characters in the JSX tokens ``. If it is `"always"` then it warns whenever a space is missing separating the mentioned two characters. The default value of this check is `"never"`. Examples of **incorrect** code for this rule, when configured with `{ "closingSlash": "never" }`: ```jsx < /Provider> ``` Examples of **correct** code for this rule, when configured with `{ "closingSlash": "never" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "closingSlash": "always" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "closingSlash": "always" }`: ```jsx < /Goodbye> ``` ### `beforeSelfClosing` This check can be set to `"always"`, `"never"`, `"proportional-always"`, or `"allow"` (to disable it). If it is `"always"`, the check warns whenever a space is missing before the closing bracket. If `"never"` then it warns if a space is present before the closing bracket. The default value of this check is `"always"`. Examples of **incorrect** code for this rule, when configured with `{ "beforeSelfClosing": "always" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "beforeSelfClosing": "always" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "beforeSelfClosing": "never" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "beforeSelfClosing": "never" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "beforeSelfClosing": "proportional-always" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "beforeSelfClosing": "proportional-always" }`: ```jsx ``` ### `afterOpening` This check can be set to `"always"`, `"never"`, `"allow-multiline"` or `"allow"` (to disable it). If it is `"always"`, the check warns whenever a space is missing after the opening bracket of either a JSX opening element or closing element. If `"never"` then it warns if a space is present after the opening bracket of either a JSX opening element or closing element. If `"allow-multiline"` then it behaves like `"never"`, but allows if the separator includes a newline character. The default value of this check is `"never"`. Examples of **incorrect** code for this rule, when configured with `{ "afterOpening": "always" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "afterOpening": "always" }`: ```jsx < Hello> < Hello firstName="John"/> < Hello firstName="John" lastName="Smith" /> ``` Examples of **incorrect** code for this rule, when configured with `{ "afterOpening": "never" }`: ```jsx < Hello> < Hello firstName="John"/> < Hello firstName="John" lastName="Smith" /> ``` Examples of **correct** code for this rule, when configured with `{ "afterOpening": "never" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "afterOpening": "allow-multiline" }`: ```jsx < Hello> < Hello firstName="John"/> < Hello firstName="John" lastName="Smith" /> ``` Examples of **correct** code for this rule, when configured with `{ "afterOpening": "allow-multiline" }`: ```jsx < Hello firstName="John" lastName="Smith" /> ``` ### `beforeClosing` This check can be set to `"always"`, `"never"`, `"proportional-always"`, or `"allow"` (to disable it). If it is `"always"` the check warns whenever whitespace is missing before the closing bracket of a JSX opening element or whenever a space is missing before the closing bracket closing element. If `"never"`, then it warns if a space is present before the closing bracket of either a JSX opening element or closing element. This rule will never warn for self closing JSX elements. The default value of this check is `"allow"`. Examples of **incorrect** code for this rule, when configured with `{ "beforeClosing": "always" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "beforeClosing": "always" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "beforeClosing": "never" }`: ```jsx ``` Examples of **correct** code for this rule, when configured with `{ "beforeClosing": "never" }`: ```jsx ``` Examples of **incorrect** code for this rule, when configured with `{ "beforeClosing": "proportional-always" }`: ```jsx Goodbye ``` Examples of **correct** code for this rule, when configured with `{ "beforeClosing": "proportional-always" }`: ```jsx Goodbye ``` ## When Not To Use It You can turn this rule off if you are not concerned with the consistency of spacing in or around JSX brackets.