1、在Nuxtjs项目中使用到了ES6的Promise对象,代码在谷歌浏览器和Edge浏览器中正常运行,而在IE浏览器和360浏览器下的兼容模式下,IE内核是不支持Promise的。
2、通过can i use网站(https://caniuse.com/)查到的ES6 promise的支持情况,可以看到IE不支持Promise。
3、要使IE浏览器兼容ES6(Promise 等语法),解决方法有两个
-
IE中,比如 Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise 等全局对象,以及一些定义在全局对象上的方法(比如 Object.assign)都不会转码。为了解决这个问题,我们使用一种叫做 Polyfill(代码填充,也可译作兼容性补丁) 的技术。
对于非node项目(了解polyfill),在页面引入browser-polyfill脚本:
可引入
<script src = "https://cdn.polyfill.io/v2/polyfill.min.js"></script>
或
<script type="text/javascript" src ="https://cdn.polyfill.io/v2/polyfill.min.js?features=es6"></script>
- 使用第三方插件bluebird.js,bluebird中对ES6的原生Promise进行了封装,解决了浏览器兼容性问题
github地址:https://github.com/petkaantonov/bluebird