Skip to content

Instantly share code, notes, and snippets.

@bendc
Created August 25, 2016 08:05
Show Gist options
  • Save bendc/d7f3dbc83d0f65ca0433caf90378cd95 to your computer and use it in GitHub Desktop.
Save bendc/d7f3dbc83d0f65ca0433caf90378cd95 to your computer and use it in GitHub Desktop.
Test if ES6 is ~fully supported
var supportsES6 = function() {
try {
new Function("(a = 0) => a");
return true;
}
catch (err) {
return false;
}
}();
@bendc
Copy link
Author

bendc commented Aug 25, 2016

Load your untranspiled ES6 file for modern browsers:

if (supportsES6) {
  var script = document.createElement("script");
  script.src = "my-es6-file.js";
  document.head.appendChild(script);
}

@rik
Copy link

rik commented Aug 25, 2016

I think this requires some performance testing since you can't benefit from browsers "parse ahead" behaviour to download the JS file as soon as possible.

@triblondon
Copy link

The ~ is pretty critical here, unless we know that for every browser, the last part of ES6 to be supported was either arrows or default args?

@triblondon
Copy link

@rik optimising for the modern browsers, you could <link rel=preload> it

@bendc
Copy link
Author

bendc commented Aug 26, 2016

@triblondon Yup, the critical test is the a = 0 (all browsers supporting default parameters have a fairly complete support of ES6 -- for example, Edge 13 will be rejected by this test despite a decent ES6 coverage).

@kenberkeley
Copy link

kenberkeley commented Mar 1, 2019

<html>
<head>
  <script>
  if (typeof Symbol === 'undefined') {
    document.write('<script crossorigin="anonymous" src="https://polyfill.io/v3/polyfill.min.js?features=es6,es7&flags=gated"><\/script>')
  }
  </script>
</head>
<body>
</body>
</html>

@cai-zhuo
Copy link

cai-zhuo commented Mar 6, 2023

@triblondon Yup, the critical test is the a = 0 (all browsers supporting default parameters have a fairly complete support of ES6 -- for example, Edge 13 will be rejected by this test despite a decent ES6 coverage).

I wanna know how to prove “all browsers supporting default parameters have a fairly complete support of ES6”
Thankfully, if you can show links or refs

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment