微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

IE不支持 Promise 解决办法

1、在Nuxtjs项目中使用到了ES6的Promise对象,代码在谷歌浏览器和Edge浏览器中正常运行,而在IE浏览器和360浏览器下的兼容模式下,IE内核是不支持Promise的。

2、通过can i use网站(https://caniuse.com/)查到的ES6 promise的支持情况,可以看到IE不支持Promise。

在这里插入图片描述

3、要使IE浏览器兼容ES6(Promise 等语法),解决方法有两个

  1. 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>
  1. 使用第三方插件bluebird.js,bluebird中对ES6的原生Promise进行了封装,解决了浏览器兼容性问题

github地址:https://github.com/petkaantonov/bluebird

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐