问题
Does anyone know, using Modernizr or otherwise, if there is a way to detect if the Promise feature is enabled in a browser?
I have a polyfill for the functionality, but only want to apply it if the browser does not have a native implementation.
回答1:
Update Dec 11 - 2016: All evergreen versions of browsers now support promises. They are safe to use.
Update Nov 14 - 2016: Chrome, Firefox, Safari and IE all now have experimental support for promises in their dev channels. The specification has settled. I would still not rely on the implementation just yet and would use a library but this might change in a few months.
No browsers support promises natively in a reliable way. The specification might change - at least for a few more months. My suggestion is use a fast promise library like Bluebird.
If you want to check if native promises are enabled - you can do :
if(typeof Promise !== "undefined" && Promise.toString().indexOf("[native code]") !== -1){
//here
}
As others suggested, just checking if there is a Promise
object can be done by if(Promise)
but I strongly suggest against it since different libraries have different APIs for creation of promises etc.
回答2:
Not so fast.
This throws when "Promise" is undefined:
if (Promise)
// do code
This never throws:
if (window.Promise)
// do code
and yes the window object can be relied upon in a browser environment.
回答3:
To create a 'supported' flag without carrying around an object reference:
var canPromise = !! window.Promise;
回答4:
You could try to create one in a try/catch
block:
var promiseSupport = false;
try {
var promise = new Promise(function (x, y) {});
promiseSupport = true;
} catch (e) {}
Check promiseSupport
to see whether or not it fails.
JSFiddle
回答5:
Here is a page listing browser and runtime support for Promise: https://kangax.github.io/compat-table/es6/
回答6:
if (Promise) {
alert("Promise is supported!");
} else {
alert("Promise is not supported!");
}
来源:https://stackoverflow.com/questions/22516959/how-to-determine-if-a-promise-is-supported-by-the-browser