The Nx Plugin for esbuild, an extremely fast JavaScript bundler. Use it to build and cache projects in an esbuild monorepo, with type-checking and asset handling layered on top.
Requirements
Section titled “Requirements”The @nx/esbuild plugin supports the following package versions.
| Package | Supported Versions |
|---|---|
esbuild | >=0.19.2 <1.0.0 |
Nx generators install the latest supported versions automatically when scaffolding new projects.
Why should you use this plugin?
- Fast builds using esbuild.
- Type-checking using TypeScript, which esbuild does not handle.
- Intelligent
package.jsonoutput. - Additional assets for the output.
Setting up @nx/esbuild
Section titled “Setting up @nx/esbuild”Installation
Section titled “Installation”In any Nx workspace, you can install @nx/esbuild by running the following command:
nx add @nx/esbuildThis will install the correct version of @nx/esbuild.
Using the @nx/esbuild plugin
Section titled “Using the @nx/esbuild plugin”Creating a new JS library
Section titled “Creating a new JS library”You can add a new library that builds using esbuild with:
nx g @nx/js:lib libs/mylib --bundler=esbuildThis command will install the esbuild plugin if needed, and set @nx/esbuild:esbuild executor for the build target.
Adding esbuild target to existing libraries
Section titled “Adding esbuild target to existing libraries”If you already have a JS project that you want to use esbuild for, run this command:
nx g @nx/esbuild:configuration mylibThis generator validates there isn't an existing build target. If you want to overwrite the existing target you can pass the --skipValidation option.
nx g @nx/esbuild:configuration mylib --skipValidationUsing esbuild
Section titled “Using esbuild”You can run builds with:
nx build mylibReplace mylib with the name or your project. This command works for both applications and libraries.
Copying assets
Section titled “Copying assets”Assets are non-JS and non-TS files, such as images, CSS, etc. You can add them to the project configuration as follows.
"build": { "executor": "@nx/esbuild:esbuild", "options": { //... "assets": [ { "input": "libs/mylib", "glob": "README.md", "output": "/" }, { "input": "libs/mylib", "glob": "logo.png", "output": "/" }, { "input": "libs/mylib", "glob": "docs/**/*.md", "output": "/docs" }, //... ] }}Running nx build mylib outputs something like this.
dist/libs/mylib/├── README.md├── docs│ ├── CONTRIBUTING.md│ └── TESTING.md├── index.js├── logo.png└── package.jsonGenerating a metafile
Section titled “Generating a metafile”A metafile can be generated by passing the --metafile option. This file contains information about the build that can be analyzed by other tools, such as bundle buddy.
nx build mylib --metafileThis command will generate a meta.json file in the output directory.
dist/libs/mylib/├── README.md├── index.js├── meta.json└── package.jsonCustom esbuild options
Section titled “Custom esbuild options”Extra API options for esbuild can be passed in the esbuildOptions object for your project configuration.
"build": { "executor": "@nx/esbuild:esbuild", "options": { //... "esbuildOptions": { "banner": { ".js": "// banner" }, "footer": { ".js": "// footer" } } }}More documentation
Section titled “More documentation”Set up CI for your esbuild monorepo
Section titled “Set up CI for your esbuild monorepo”In CI, Nx runs nx affected to rebuild and retest only the projects a change touches, and caches results to skip repeated work.
For a complete pipeline, see Set up CI.