React Compiler: what does it do and what's new?
Johannes Schickling
@johanne-schickling
Johannes Schickling
@johanne-schickling
The React Compiler is a experimental compiler that has been open sources to the community in order to receive feedback and ideas. As you can imagine this means it is not production ready yet. However, it is a great way to get a feel for what this compiler of React does and can do. Keep in mind that this experimental compiler needs React 19 to work.
The main purpose of the React Compiler is to memoize your application and make it thus faster and more efficient.
In a lot of cases and projects the current way of working is to add common API's to your application and then use them in your components.
API's like useMemo
, useCallback
, and React.memo
are great in this aspect but hard to understand and maintain for a great part of the community, and let's be honest, they are not always the best solution.
These API's are also often used in a incorrect way or are forgotten to be used. Thus the React team created the React Compiler to help you with this.
Keep in mind that if your project is already correctly memoized that you might not see that any or little performance improvements.
In the React team their own words the compiler assumes that your code:
strictNullChecks
if using TypeScript), i.e., if (object.nullableProperty) { object.nullableProperty.foo }
or with optional-chaining object.nullableProperty?.foo
Follows the Rules of ReactYou can check if your codebase is compatible with the React Compiler by running the following command:
What this script will do is check how many components can be successfully optimized, if <StrictMode>
is used, and if incompatible libraries are used.
An example of n output can be seen below:
There is also an eslint plugin available that you can use to check your codebase for compatibility with the React Compiler. You can install it with the following command:
And then add it to your eslint config file:
This plugin is very helpful as it will display all the violations that can occur in your codebase with the React Compiler. If you see an error it means that the compiler has skipped optimization of that component, this will not block your application from running as the compiler will recover and continue.
As I mostly write about Next.js I will not go into detail on how to enable it for your project that does not use Next.js. But you can read onward from here in order to set it up for your project.
For Next.js however to setup to use the compiler do the following:
Then add the following to your next.config.js
file:
The React Devtools version 5 has built-in support for React Compiler and will display a “Memo ✨” badge next to components that have been optimized by the compiler.