@nx/js

The JS plugin contains executors and generators that are useful for JavaScript/TypeScript projects in an Nx workspace.

Setting Up @nx/js

Installation

Keep Nx Package Versions In Sync

Make sure to install the @nx/js version that matches the version of nx in your repository. If the version numbers get out of sync, you can encounter some difficult to debug errors. You can fix Nx version mismatches with this recipe.

In any Nx workspace, you can install @nx/js by running the following command:

โฏ

nx add @nx/js

This will install the correct version of @nx/js.

ts Preset

When initializing a new Nx workspace, specifying --preset=ts will generate a workspace with @nx/js pre-installed.

โฏ

npx create-nx-workspace my-org --preset=ts

Modernized monorepo setup

Nx 20 updates the TS monorepo setup when using --preset=ts. The workspace is set up with TypeScript Project References along with the Workspaces feature from npm, yarn, pnpm, and bun.

To create with the older setup for TS monorepo with compilerOptions.paths, use create-nx-workspace --preset=apps.

Create Libraries

You can add a new JS/TS library with the following command:

โฏ

nx g @nx/js:lib libs/my-lib

Build

You can build libraries that are generated with a bundler specified.

โฏ

nx g @nx/js:lib libs/my-buildable-lib --bundler=rollup

Generating a library with --bundler specified will add a build target to the library's project.json file allows the library to be built.

โฏ

nx build my-buildable-lib

Test

You can test a library with the following command:

โฏ

nx test my-lib

Lint

You can lint a library with the following command:

โฏ

nx lint my-lib

Compiler

By default, @nx/js uses TypeScript Compiler (TSC), via @nx/js:tsc executor, to compile your libraries. Optionally, you can switch tsc out for a different compiler with --compiler flag when executing the generators.

Currently, @nx/js supports the following compilers:

SWC

  • Create a buildable library with swc

โฏ

nx g @nx/js:lib libs/my-swc-lib --bundler=swc

  • Convert a tsc library to use swc

โฏ

nx g @nx/js:convert-to-swc my-buildable-lib

Now the build command will use @nx/js:swc executor to compile your libraries.

The first time you generate a swc library or convert a tsc library over to swc, @nx/js will install the necessary dependencies to use swc.

Package reference

Here is a list of all the executors, generators and migrations available from this package.

Guides

Executors

  • tsc

    Build a project using TypeScript.

  • swc

    Build a project using SWC.

  • node

    Execute a Node application.

  • release-publishInternal

    DO NOT INVOKE DIRECTLY WITH nx run. Use nx release publish instead.

  • verdaccio

    Start local registry with verdaccio

Generators

Migrations

  • 20.4.x

  • 20.4.0-package-updates

    Version: 20.4.0-beta.1

    Requires

    NameVersion
    typescript>=5.6.0 <5.7.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.7.2Update only
  • 20.2.x

  • 20.2.0-package-updates

    Version: 20.2.0-beta.5

    Requires

    NameVersion
    typescript>=5.5.0 <5.6.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.6.2Update only
  • 19.5.x

  • 19.5.1-package-updates

    Version: 19.5.0-beta.1

    Requires

    NameVersion
    typescript>=5.4.0 <5.5.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.5.2Update only
  • 19.2.x

  • 19.2.0-package-updates

    Version: 19.2.0-beta.0

    Packages

    NameVersionAlways Add to package.json
    @swc/core~1.5.7Update only
    @swc/helpers~0.5.11Update only
    @swc-node/register~1.9.1Update only
  • 19.0.x

  • 19.0.0-package-updates

    Version: 19.0.0-beta.0

    Packages

    NameVersionAlways Add to package.json
    @swc/cli~0.3.12Update only
  • 18.2.x

  • 18.2.0-package-updates

    Version: 18.2.0-beta.0

    Requires

    NameVersion
    typescript>=5.3.0 <5.4.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.4.2Update only
  • 18.0.x

  • 18.0.4-package-updates

    Version: 18.0.4-beta.0

    Packages

    NameVersionAlways Add to package.json
    @swc-node/register~1.8.0Update only
  • 17.3.x

  • 17.3.0-beta.10-package-updates

    Version: 17.3.0-beta.10

    Requires

    NameVersion
    typescript>=5.2.0 <5.3.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.3.2Update only

    17.3.0-package-updates

    Version: 17.3.0-beta.3

    Packages

    NameVersionAlways Add to package.json
    @types/node^18.16.9Update only
  • 17.1.x

  • 17.1.0-package-updates

    Version: 17.1.0-beta.4

    Requires

    NameVersion
    typescript>=5.1.0 <5.2.0

    Packages

    NameVersionAlways Add to package.json
    typescript~5.2.2Update only
  • 17.0.x

  • update-17-0-0-remove-deprecated-build-options

    Remove deprecated build options

    Version: 17.0.2

    17.0.0-package-updates

    Version: 17.0.0-rc.2

    Packages

    NameVersionAlways Add to package.json
    esbuild^0.19.2Update only