diff --git a/README.md b/README.md index b72954e8..b7cab449 100644 --- a/README.md +++ b/README.md @@ -243,7 +243,7 @@ Browser compatibility **without** ES Module Shims: | [CSS Modules](#css-modules) | 95+ | :x: | :x: | | [Wasm Modules](#wasm-modules) | :x: | :x: | :x: | | [import.meta.resolve](#resolve) | :x: | :x: | :x: | -| [Module Workers](#module-workers) | ~68+ | :x: | :x: | +| [Module Workers](#module-workers) | ~68+ | ~113+ | 15+ | | Top-Level Await | 89+ | 89+ | 15+ | * ❕1: On module redirects, Safari returns the request URL in `import.meta.url` instead of the response URL as per the spec. @@ -490,7 +490,7 @@ Node.js also implements a similar API, although it's in the process of shifting ### Module Workers -ES Module Shims can be used in module workers in browsers that provide dynamic import in worker environments, which at the moment are Chrome(80+), Edge(80+) and Safari(15+). +ES Module Shims can be used in module workers in browsers that provide dynamic import in worker environments, which at the moment are Chrome(80+), Edge(80+), Firefox(~113+) and Safari(15+). By default, when there is no DOM present, ES Module Shims will switch into shim mode. An example of ES Module Shims usage through shim mode in web workers is provided below: @@ -528,6 +528,7 @@ Provide a `esmsInitOptions` on the global scope before `es-module-shims` is load * [mapOverrides](#overriding-import-map-entries) * [modulepreload](#modulepreload) * [noLoadEventRetriggers](#no-load-event-retriggers) +* [globalLoadEventRetrigger](#global-load-event-retrigger) * [nonce](#nonce) * [onerror](#error-hook) * [onpolyfill](#polyfill-hook) @@ -546,8 +547,10 @@ window.esmsInitOptions = { polyfillEnable: ['css-modules', 'json-modules'], // default empty // Custom CSP nonce nonce: 'n0nce', // default is automatic detection - // Don't retrigger load events on module scripts + // Don't retrigger load events on module scripts (DOMContentLoaded, domready) noLoadEventRetriggers: true, // default false + // Retrigger window 'load' event (will be combined into load event above on next major) + globalLoadEventRetrigger: true, // default false // Skip source analysis of certain URLs for full native passthrough skip: /^https:\/\/cdn\.com/, // defaults to null // Clean up blob URLs after execution @@ -667,7 +670,7 @@ Alternatively, add a `blob:` URL policy with the CSP build to get CSP compatibil ### No Load Event Retriggers -Because of the extra processing done by ES Module Shims it is possible for static module scripts to execute after the `load`, `DOMContentLoaded` or `readystatechange` events they expect, which can cause missed attachment. +Because of the extra processing done by ES Module Shims it is possible for static module scripts to execute after the `DOMContentLoaded` or `readystatechange` events they expect, which can cause missed attachment. In addition, script elements will also have their load events refired when polyfilled. @@ -678,13 +681,20 @@ In such a case, this double event firing can be disabled with the `noLoadEventRe ```js ``` +### Global Load Event Retrigger + +In ES Module Shims 1.x, load event retriggers only apply to `DOMContentLoaded` and `readystatechange` and not to the window `load` event. +To enable the window / worker `'load'` event, set `globalLoadEventRetrigger: true`. + +In the next major version, this will be the default for load events, at which point only `noLoadEventRetriggers` will remain. + ### Skip When loading modules that you know will only use baseline modules features, it is possible to set a rule to explicitly opt-out modules from being polyfilled to always load and be referenced through the native loader only. This enables instance sharing with the native loader and also improves performance because those modules then do not need to be processed or transformed at all, so that only local application code is handled and not library code. diff --git a/resources/testharness.js b/resources/testharness.js index 16338cd2..59cc3b8b 100644 --- a/resources/testharness.js +++ b/resources/testharness.js @@ -4977,6 +4977,7 @@ table#results span.actual {\ // ADDITIONS: window.esmsInitOptions = { + globalLoadEventRetrigger: true, polyfillEnable: ['wasm-modules', 'source-phase'] }; document.write('<' + 'script src="../dist/es-module-shims.js">' + '<' + `script> diff --git a/src/env.js b/src/env.js index feb400fa..563ee01f 100644 --- a/src/env.js +++ b/src/env.js @@ -26,7 +26,7 @@ if (!nonce && hasDocument) { export const onerror = globalHook(esmsInitOptions.onerror || noop); -export const { revokeBlobURLs, noLoadEventRetriggers, enforceIntegrity } = esmsInitOptions; +export const { revokeBlobURLs, noLoadEventRetriggers, globalLoadEventRetrigger, enforceIntegrity } = esmsInitOptions; function globalHook (name) { return typeof name === 'string' ? self[name] : name; diff --git a/src/es-module-shims.js b/src/es-module-shims.js index ac356b20..225ca044 100755 --- a/src/es-module-shims.js +++ b/src/es-module-shims.js @@ -18,6 +18,7 @@ import { skip, revokeBlobURLs, noLoadEventRetriggers, + globalLoadEventRetrigger, cssModulesEnabled, jsonModulesEnabled, wasmModulesEnabled, @@ -616,7 +617,7 @@ function domContentLoadedCheck () { } let loadCnt = 1; function loadCheck () { - if (--loadCnt === 0 && !noLoadEventRetriggers && (shimMode || !baselinePassthrough)) { + if (--loadCnt === 0 && globalLoadEventRetrigger && !noLoadEventRetriggers && (shimMode || !baselinePassthrough)) { if (self.ESMS_DEBUG) console.info(`es-module-shims: load refire`); window.dispatchEvent(new Event('load')); }