axios在ie浏览器下提示promise未定义

手机兼职赚零花钱,一天赚个三五十元,点击了解

最近修改项目的兼容性,项目测试ie11兼容性时发现axios会提示promise未定义,在chrome下完全没毛病,怎么去到ie11就报promise未定义了呢?

翻了一轮axios的文档终于发现问题原因。

在ie11下直接使用axios会报Promise未定义,这是因为axios本质上是封装了ES6语法的promise,而promise在IE上并不兼容。

这时只需要引入babel-pollfile就行了。babel-Polyfill相当于一个ES6的兼容垫片, 它会仿效一个完整的ES2015+环境,从而让某些浏览器也能读懂。

npm install --save babel-polyfill

然后在main.js的顶部引入import "babel-polyfill"; 最好给它最优先加载。

随后在build目录下webpack.config.js(如果你是vue-cli项目的话那就是build目录下webpack.base.conf.js)设置app载入babel-polyfill。

module.exports = {

    entry: {

            app: ["babel-polyfill",'./src/main.js']

    }

添加完之后,刷新一下浏览器,promise未定义就消失啦!

babel-polyfill官网https://babeljs.io/docs/en/babel-polyfill/



作者:Elivs_欧元
链接:https://www.jianshu.com/p/33e5ec794d9a
來源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。


微信赚钱一天赚100元,点击了解
版权声明

本文仅代表作者观点,不代表本站立场。
本文系作者授权发表,未经许可,不得转载。

评论

Top