64 lines
2.1 KiB
Markdown
64 lines
2.1 KiB
Markdown
# babel-preset-react-app
|
||
|
||
This package includes the Babel preset used by [Create React App](https://github.com/facebook/create-react-app).<br>
|
||
Please refer to its documentation:
|
||
|
||
- [Getting Started](https://facebook.github.io/create-react-app/docs/getting-started) – How to create a new app.
|
||
- [User Guide](https://facebook.github.io/create-react-app/) – How to develop apps bootstrapped with Create React App.
|
||
|
||
## Usage in Create React App Projects
|
||
|
||
The easiest way to use this configuration is with [Create React App](https://github.com/facebook/create-react-app), which includes it by default. **You don’t need to install it separately in Create React App projects.**
|
||
|
||
## Usage Outside of Create React App
|
||
|
||
If you want to use this Babel preset in a project not built with Create React App, you can install it with the following steps.
|
||
|
||
First, [install Babel](https://babeljs.io/docs/setup/).
|
||
|
||
Then install babel-preset-react-app.
|
||
|
||
```sh
|
||
npm install babel-preset-react-app --save-dev
|
||
```
|
||
|
||
Then create a file named `.babelrc` with following contents in the root folder of your project:
|
||
|
||
```json
|
||
{
|
||
"presets": ["react-app"]
|
||
}
|
||
```
|
||
|
||
This preset uses the `useBuiltIns` option with [transform-object-rest-spread](https://babeljs.io/docs/plugins/transform-object-rest-spread/) and [transform-react-jsx](https://babeljs.io/docs/plugins/transform-react-jsx/), which assumes that `Object.assign` is available or polyfilled.
|
||
|
||
## Usage with Flow
|
||
|
||
Make sure you have a `.flowconfig` file at the root directory. You can also use the `flow` option on `.babelrc`:
|
||
|
||
```json
|
||
{
|
||
"presets": [["react-app", { "flow": true, "typescript": false }]]
|
||
}
|
||
```
|
||
|
||
## Usage with TypeScript
|
||
|
||
Make sure you have a `tsconfig.json` file at the root directory. You can also use the `typescript` option on `.babelrc`:
|
||
|
||
```json
|
||
{
|
||
"presets": [["react-app", { "flow": false, "typescript": true }]]
|
||
}
|
||
```
|
||
|
||
## Absolute Runtime Paths
|
||
|
||
Absolute paths are enabled by default for imports. To use relative paths instead, set the `absoluteRuntime` option in `.babelrc` to `false`:
|
||
|
||
```
|
||
{
|
||
"presets": [["react-app", { "absoluteRuntime": false }]]
|
||
}
|
||
```
|