---
id: jsx-in-depth
title: JSX In Depth
permalink: docs/jsx-in-depth.html
redirect_from:
- "docs/jsx-spread.html"
- "docs/jsx-gotchas.html"
- "tips/if-else-in-JSX.html"
- "tips/self-closing-tag.html"
- "tips/maximum-number-of-jsx-root-nodes.html"
- "tips/children-props-type.html"
- "docs/jsx-in-depth-zh-CN.html"
- "docs/jsx-in-depth-ko-KR.html"
---
Fundamentally, JSX just provides syntactic sugar for the `React.createElement(component, props, ...children)` function. The JSX code:
```js
Click Me
```
compiles into:
```js
React.createElement(
MyButton,
{color: 'blue', shadowSize: 2},
'Click Me'
)
```
You can also use the self-closing form of the tag if there are no children. So:
```js
```
compiles into:
```js
React.createElement(
'div',
{className: 'sidebar'},
null
)
```
If you want to test out how some specific JSX is converted into JavaScript, you can try out [the online Babel compiler](https://babeljs.io/repl/#?babili=false&evaluate=true&lineWrap=false&presets=es2015%2Creact%2Cstage-0&code=function%20hello()%20%7B%0A%20%20return%20%3Cdiv%3EHello%20world!%3C%2Fdiv%3E%3B%0A%7D).
## Specifying The React Element Type
The first part of a JSX tag determines the type of the React element.
Capitalized types indicate that the JSX tag is referring to a React component. These tags get compiled into a direct reference to the named variable, so if you use the JSX `` expression, `Foo` must be in scope.
### React Must Be in Scope
Since JSX compiles into calls to `React.createElement`, the `React` library must also always be in scope from your JSX code.
For example, both of the imports are necessary in this code, even though `React` and `CustomButton` are not directly referenced from JavaScript:
```js{1,2,5}
import React from 'react';
import CustomButton from './CustomButton';
function WarningButton() {
// return React.createElement(CustomButton, {color: 'red'}, null);
return ;
}
```
If you don't use a JavaScript bundler and loaded React from a `