* Because JSX compiled into `React.createElement`, `React` needed to be in scope if you use JSX.
* Because JSX compiled into `React.createElement`, `React` needed to be in scope if you use JSX.
* There are some [performance improvements and simplifications](https://github.com/reactjs/rfcs/blob/createlement-rfc/text/0000-create-element-changes.md#motivation) that `React.createElement` does not allow.
* There are some [performance improvements and simplifications](https://github.com/reactjs/rfcs/blob/createlement-rfc/text/0000-create-element-changes.md#motivation) that `React.createElement` does not allow.
To solve these issues, React 17 introduces two new entry points to the React package that are intended to only be used by compilers like Babel and TypeScript. Instead of transforming JSX to `React.createElement`, **the new JSX transform** automatically imports special functions from those new entry points in the React package and calls them. For example,
To solve these issues, React 17 introduces two new entry points to the React package that are intended to only be used by compilers like Babel and TypeScript. Instead of transforming JSX to `React.createElement`, **the new JSX transform** automatically imports special functions from those new entry points in the React package and calls them.
Let's say that your source code looks like this:
```js
```js
function App() {
function App() {
@ -65,7 +67,7 @@ function App() {
}
}
```
```
will now be transformed to
This is what the new JSX transform compiles it to:
```js
```js
// Inserted by a compiler (don't import it yourself!)
// Inserted by a compiler (don't import it yourself!)