Node.js

In this document, you will learn how to build a Node.js library using Rslib.

Create Node.js project

You can use create-rslib to create a project with Rslib + Node.js. Just execute the following command:

npm
yarn
pnpm
bun
npm create rslib@latest

Then select Node.js when prompted to "Select template".

Use Rslib in an existing project

Rslib offers seamless support for Node.js projects, allowing you to build Node.js project effortlessly with minimal configuration.

For example, in rslib.config.ts:

rslib.config.ts
import { defineConfig } from '@rslib/core';

export default defineConfig({
  lib: [
    {
      format: 'esm',
      output: {
        distPath: {
          root: './dist/esm',
        },
      },
    },
    {
      format: 'cjs',
      output: {
        distPath: {
          root: './dist/cjs',
        },
      },
    },
  ],
});

Target for Node.js

Rslib set target to "node" by default, which is different from the default target of Rsbuild.

When target is set to "node", Rslib adjusts many configurations for Node.js. For example, output.externals will exclude built-in Node.js modules, and shims will add a shim for import.meta.url in CJS output by default.

Externals

All Node.js built-in modules are externalized by default.

Shims

  • global: leave it as it is, while it's recommended to use globalThis instead.
  • __filename: When outputting in ESM format, replace __filename with the result of fileURLToPath(import.meta.url).
  • __dirname: When outputting in ESM format, replace __dirname with the result of dirname(fileURLToPath(import.meta.url)).