Migrating a Create-React-App project into an Nx Workspace
Create-React-App (CRA) is one of the most widely used tool for creating, building and testing a React app. This guide will show you how move an app generated with CRA into an Nx workspace. Once the migration process is complete, you'll be able to take advantage of all of Nx's features without needing to completely recreate your build process.
Automated migration
The easiest way to setup Nx in your CRA project is to use the automated migration tool.
npx nx init
The command above will detect that the project is generated with CRA, and that it has not been ejected, or _ customized_ with either react-app-rewired
or @craco/craco
. If the project has either been ejected or customized, then the migration will still continue but you will be prompted for more information.
That's it!
ViteYou will notice that the project now uses Vite and Vitest to build and test your application. Vite is a next-gen tooling for building frontend applications, and is much faster than Webpack ( which CRA uses).
If you do not want to use Vite, you can run npx nx init --vite=false
instead.
Try Nx
echo "SKIP_PREFLIGHT_CHECK=true" > .env
### 10. Add all node_modules to .gitignore
An `apps/webapp/node_modules` folder will be generated to hold some cache values when a build is run. This cache shouldn't be committed to git, so we tell git to ignore any `node_modules` folder.
```shell
echo "node_modules" >> .gitignore
Try Nx
The same scripts you used before still work.
npm start
npm run build
npm test
build
and test
are set up to automatically cache their results. Subsequent runs of npm run build
(without changing any code), for example, should only take a couple seconds.