From 1f7b577c01c808a31e11d40fe30eac0083eeb30b Mon Sep 17 00:00:00 2001 From: Geoffrey Booth Date: Mon, 11 Nov 2019 21:12:17 -0800 Subject: [PATCH] doc: esm: revisions per feedback --- doc/api/esm.md | 40 ++++++++++++++++++++++++++++++++++++---- 1 file changed, 36 insertions(+), 4 deletions(-) diff --git a/doc/api/esm.md b/doc/api/esm.md index fc24802a76e4bc..bec7e2cb270592 100644 --- a/doc/api/esm.md +++ b/doc/api/esm.md @@ -499,6 +499,11 @@ create an ES module wrapper file that defines the named exports. Using ES module wrapper is used for `import` and the CommonJS entry point for `require`. +> Note: While `--experimental-conditional-exports` is flagged, a package +> using this pattern will throw when loaded via `require()` in modern +> Node.js, unless package consumers use the `--experimental-conditional-exports` +> flag. + ```js // ./node_modules/pkg/package.json @@ -553,13 +558,13 @@ This approach is appropriate for any of the following use cases: * The package stores internal state, and the package author would prefer not to refactor the package to isolate its state management. See the next section. -A variant of this approach would add an export, e.g. `"./module"`, to point to -an all-ES module-syntax version the package. This could be used via `import +A variant of this approach not requiring `--experimental-conditional-exports` +for consumers could be to add an export, e.g. `"./module"`, to point to an +all-ES module-syntax version the package. This could be used via `import 'pkg/module'` by users who are certain that the CommonJS version will not be loaded anywhere in the application, such as by dependencies; or if the CommonJS version can be loaded but doesn’t affect the ES module version (for example, -because the package is stateless). This variant would not require -`--experimental-conditional-exports`: +because the package is stateless): ```js @@ -574,6 +579,11 @@ because the package is stateless). This variant would not require } ``` +If the `--experimental-conditional-exports` flag is dropped and therefore +[Conditional Exports][] become available without a flag, this variant could be +easily updated to use conditional exports by adding conditions to the `"."` +path; while keeping `"./module"` for backward compatibility. + ##### Approach #2: Isolate State The most straightforward `package.json` would be one that defines the separate @@ -659,6 +669,28 @@ This approach is appropriate for any of the following use cases: Even with isolated state, there is still the cost of possible extra code execution between the CommonJS and ES module versions of a package. +As with the previous approach, a variant of this approach not requiring +`--experimental-conditional-exports` for consumers could be to add an export, +e.g. `"./module"`, to point to an all-ES module-syntax version the package: + + +```js +// ./node_modules/pkg/package.json +{ + "type": "module", + "main": "./index.cjs", + "exports": { + ".": "./index.cjs", + "./module": "./index.mjs" + } +} +``` + +If the `--experimental-conditional-exports` flag is dropped and therefore +[Conditional Exports][] become available without a flag, this variant could be +easily updated to use conditional exports by adding conditions to the `"."` +path; while keeping `"./module"` for backward compatibility. + ## import Specifiers ### Terminology