Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
babel-preset-expo
Advanced tools
babel-preset-expo is a Babel preset specifically designed for Expo projects. It includes a set of Babel plugins and configurations that are optimized for React Native development using Expo. This preset simplifies the setup process and ensures compatibility with Expo's ecosystem.
Transform JSX
This feature allows you to transform JSX syntax into JavaScript. By using babel-preset-expo, you can write JSX code in your Expo project, and Babel will handle the transformation.
module.exports = function(api) {
api.cache(true);
return {
presets: ['babel-preset-expo'],
};
};
Class Properties
This feature allows you to use class properties in your React components. The babel-preset-expo preset includes the necessary plugins to support this syntax.
class MyComponent extends React.Component {
state = { count: 0 };
increment = () => {
this.setState({ count: this.state.count + 1 });
};
render() {
return (
<button onClick={this.increment}>Increment</button>
);
}
}
Optional Chaining
This feature allows you to use optional chaining in your JavaScript code. The babel-preset-expo preset includes the necessary plugins to support this syntax, making it easier to work with deeply nested objects.
const user = { name: 'John', address: { city: 'New York' } };
const city = user?.address?.city;
babel-preset-react-native is a Babel preset specifically designed for React Native projects. It includes a set of Babel plugins and configurations optimized for React Native development. While it is similar to babel-preset-expo, it does not include Expo-specific configurations and optimizations.
babel-preset-env is a Babel preset that allows you to use the latest JavaScript features without needing to micromanage which syntax transforms (and optionally, browser polyfills) are needed by your target environment(s). It is more general-purpose compared to babel-preset-expo, which is tailored for Expo projects.
babel-preset-stage-3 is a Babel preset that includes plugins for stage 3 proposals of ECMAScript. It allows you to use experimental JavaScript features that are close to being finalized. While it provides cutting-edge features, it is not specifically optimized for React Native or Expo projects like babel-preset-expo.
This preset extends the default React Native preset (metro-react-native-babel-preset
) and adds support for decorators, tree-shaking web packages, and loading font icons with optional native dependencies if they're installed.
You can use this preset in any React Native project as a drop-in replacement for metro-react-native-babel-preset
. If your project isn't using native font loading or web support then this preset will only add support for decorators with @babel/plugin-proposal-decorators
- this is mostly used for supporting legacy community libraries.
If you start your web project with @expo/webpack-config
or npx expo start
and your project doesn't contain a babel.config.js
or a .babelrc
then it will default to using babel-preset-expo
for loading.
If you have problems with the code in this repository, please file issues & bug reports at https://github.com/expo/expo. Thanks!
A bundler must follow these requirements if they are to be considered spec compliant for use with a universal React (Expo) project.
The babel loading mechanism must include the following properties on its caller
.
A platform
property denoting the target platform. If the platform
is not defined, it will default to using web
when the bundler
is webpack
-- this is temporary and will throw an error in the future.
Value | Description |
---|---|
ios | Runs on iOS devices |
android | Runs on Android devices |
web | Runs in web browsers |
A bundler
property denoting the name of the bundler that is being used to create the JavaScript bundle.
If the bundler
is not defined, it will default to checking if a babel-loader
is used, if so then webpack
will be used, otherwise it will default to metro
.
Value | Description |
---|---|
metro | Bundling with Metro |
webpack | Bundling with Webpack |
reanimated
boolean
, defaults to true
. Set reanimated: false
to disable adding the react-native-reanimated/plugin
when react-native-reanimated
is installed.
jsxRuntime
classic | automatic
, defaults to automatic
automatic
automatically convert JSX to JS without the need to import React from 'react'
in every file. Be sure to follow the rest of the setup guide after enabling this, otherwise ESLint and other tools will throw warnings.classic
does not automatically import anything, React must imported into every file that uses JSX syntax.[
'babel-preset-expo',
{
jsxRuntime: 'classic',
},
];
This property is passed down to @babel/plugin-transform-react-jsx
. This flag does nothing when useTransformReactJSXExperimental
is set to true
because @babel/plugin-transform-react-jsx
is omitted.
jsxImportSource
string
, defaults to react
This option allows specifying a custom import source for importing functions.
[
'babel-preset-expo',
{
jsxRuntime: 'automatic',
jsxImportSource: 'react',
},
];
This property is passed down to @babel/plugin-transform-react-jsx
. This options does nothing when jsxRuntime
is not set to automatic
.
lazyImports
Changes Babel's compiled import
statements to be lazily evaluated when their imported bindings are used for the first time.
Note: this option has an effect only when the disableImportExportTransform
option is set to false
. On Android and iOS, disableImportExportTransform
defaults to false
, and on web it defaults to true
to allow for tree shaking.
This can improve the initial load time of your app because evaluating dependencies up front is sometimes entirely un-necessary, particularly when the dependencies have no side effects.
The value of lazyImports
has a few possible effects:
null
- metro-react-native-babel-preset will handle it. (Learn more about it here: https://github.com/facebook/metro/commit/23e3503dde5f914f3e642ef214f508d0a699851d)
false
- No lazy initialization of any imported module.
true
- Lazy-init all imported modules except local imports (e.g., ./foo
), certain Expo packages that have side effects, and the two cases mentioned here.
Array<string>
- babel-plugin-transform-modules-commonjs will handle it.
(string) => boolean
- babel-plugin-transform-modules-commonjs will handle it.
If you choose to do this, you can also access the list of Expo packages that have side effects by using const lazyImportsBlacklist = require('babel-preset-expo/lazy-imports-blacklist');
which returns a Set
.
default: null
[
'babel-preset-expo',
{
lazyImports: true
}
],
disableImportExportTransform
Enabling this option will allow your project to run with older JavaScript syntax (i.e. module.exports
). This option will break tree shaking and increase your bundle size, but will eliminate the following error when module.exports
is used:
TypeError: Cannot assign to read only property 'exports' of object '#<Object>'
default: false
when using Webpack. true
otherwise.
[
'babel-preset-expo',
{
disableImportExportTransform: true
}
],
unstable_transformProfile
Changes the engine preset in metro-react-native-babel-preset
based on the JavaScript engine that is being targeted. In Expo SDK 50 and greater, this is automatically set based on the jsEngine
option in your app.json
.
enableBabelRuntime
Passed to metro-react-native-babel-preset
.
disableFlowStripTypesTransform
Passed to metro-react-native-babel-preset
.
All options can be passed in the platform-specific objects native
and web
to provide different settings on different platforms. For example, if you'd like to only apply disableImportExportTransform
on web, use the following:
[
'babel-preset-expo',
{
// Default value:
disableImportExportTransform: false,
web: {
// Web-specific value:
disableImportExportTransform: true,
},
},
];
Platform-specific options have higher priority over top-level options.
FAQs
The Babel preset for Expo projects
The npm package babel-preset-expo receives a total of 690,528 weekly downloads. As such, babel-preset-expo popularity was classified as popular.
We found that babel-preset-expo demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 28 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.