As title, how can I detect async/await es7 support in browser?
Is that possible?
As title, how can I detect async/await es7 support in browser?
Is that possible?
Currently there is no perfect solution for that, but it can be done using eval
:
let isAsyncSupported;
try {
isAsyncSupported = eval(`typeof Object.getPrototypeOf(async function() {}).constructor === 'function'`);
} catch (exception) {
isAsyncSupported = false;
}
For more see:
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/AsyncFunction
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function
As any other syntactic feature, it should be evaluated in order to be detected. Since
eval
can be restricted, this may be impossible when CSP is enabled:If there's a chance that target browsers don't support a feature, the code should be transpiled.
The alternative that allows to avoid CSP restrictions on
eval
is to use external script to detect syntactic features, as described here.