JavaScript modules via script tag

- LS

Loading JavaScript module scripts (aka ES6 modules) using <script type="module"> Includes support for the nomodule attribute.

Chrome

  1. 4 - 59: Not supported
  2. 60: Disabled by default
  3. 61 - 127: Supported
  4. 128: Supported
  5. 129 - 131: Supported

Edge

  1. 12 - 14: Not supported
  2. 15: Disabled by default
  3. 16 - 18: Supported
  4. 79 - 127: Supported
  5. 128: Supported

Safari

  1. 3.1 - 10: Not supported
  2. 10.1: Partial support
  3. 11 - 17.4: Supported
  4. 17.5: Supported
  5. 17.6 - TP: Supported

Firefox

  1. 2 - 53: Not supported
  2. 54 - 59: Disabled by default
  3. 60 - 129: Supported
  4. 130: Supported
  5. 131 - 133: Supported

Opera

  1. 9 - 46: Not supported
  2. 47: Disabled by default
  3. 48 - 110: Supported
  4. 111: Supported

IE

  1. 5.5 - 10: Not supported
  2. 11: Not supported

Chrome for Android

  1. 128: Supported

Safari on iOS

  1. 3.2 - 10.2: Not supported
  2. 10.3: Partial support
  3. 11 - 17.4: Supported
  4. 17.5: Supported
  5. 17.6 - 18.0: Supported

Samsung Internet

  1. 4 - 7.4: Not supported
  2. 8.2 - 24: Supported
  3. 25: Supported

Opera Mini

  1. all: Not supported

Opera Mobile

  1. 10 - 12.1: Not supported
  2. 80: Supported

UC Browser for Android

  1. 15.5: Supported

Android Browser

  1. 2.1 - 4.4.4: Not supported
  2. 128: Supported

Firefox for Android

  1. 127: Supported

QQ Browser

  1. 14.9: Supported

Baidu Browser

  1. 13.52: Supported

KaiOS Browser

  1. 2.5: Not supported
  2. 3: Supported
Resources:
Blog post: Native ECMAScript modules - the first overview
MS Edge blog post
Firefox support bug
Will it double-fetch? Browser behavior with `module` / `nomodule` scripts
Mozilla hacks article
Blog post on using nomodule
Specification for nomodule attribute
Intro to ES6 modules
Counterpart ECMAScript specification for import/export syntax
Sub-features:
JavaScript modules: dynamic import()