前言vue
由于工做的须要,学习Vue2.0也有一段时间,最近在用Vue2.0的官方脚手架工具构建的项目,chrome中跑一直没有问题,但ie打开出现了bug:webpack
问题web
ie打开vue2.0项目空白,控制台报错 vuex requires a Promise polyfill in this browser;
vuex
缘由chrome
Babel 默认只转换新的 JavaScript 句法(syntax),而不转换新的 API ,好比 Iterator、Generator、Set、Maps、Proxy、Reflect、Symbol、Promise 等全局对象,以及一些定义在全局对象上的方法(好比 Object.assign)都不会转码。为了解决这个问题,咱们使用一种叫作 Polyfill(代码填充,也可译做兼容性补丁) 的技术。vue-cli
简单地说,polyfill便是在当前运行环境中用来复制(意指模拟性的复制,而不是拷贝)尚不存在的原生 api 的代码。npm
解决api
安装babel-polyfill
bash
步骤babel
npm安装 npm
install
--save-dev babel-polyfill 或 c
npm
install
--save-dev babel-polyfill
在main.js导入便可 import 'babel-polyfill'
若是也是用了官方脚手架vue-cli,还须要在webpack.config.js配置文件中作各修改,用
module.exports = {
entry: {
app: [
"babel-polyfill"
,
"./src/main.js"
]
}
};
module.exports = {
entry: {
app:
'./src/main.js'
}
}