vue 项目在ie浏览器的兼容问题

注意:

  1. vue 只兼容ie8以上版本;
  2. IE 不兼容 axios的promiss对象;
  3. IE 不兼容es6语法;
  4. ES6转ES5

一、关于babel-polyfill

1、说明:This will emulate a full ES2015+ environment and is intended to be used in an application rather than a library/tool. This polyfill is automatically loaded when using babel-node.(模拟ES2015以上的环境,主要用于对ES6新语法不支持的浏览器);

2、安装:npm install --save babel-polyfill;

3、配置:module.exports = { entry: ["babel-polyfill", "./src/main.js"] };

4、main.js中配置:import 'babel-polyfill' //放在最顶部,确保全面加载。

二、关于es6-promise

1、说明:若在项目中使用了ES6 promise对象,它在Chrome、Safari浏览器下可以正常运行,但在360兼容模式、IE内核中不支持;

2、安装:npm install es6-promise;

3、配置:在main.js中加入require('es6-promise').polyfill(),用于在node或浏览器中支持ES6 与CommonJS。

三、步骤详细图
1、index引入这句话或者这三句话
index.html
2、执行npm install --save babel-polyfill;
执行完上面语句package.json里面就有了这个依赖(检查2部是否执行完成的一个结果)
在这里插入图片描述

3、最上面引入,确保加载进去。
在这里插入图片描述
4、修改entery里面的内容改成下图那样
在这里插入图片描述
四、问题如图:
当把这些攻略都做了一遍后,发现打包完的360的急速模式可以了(本地运行还是不可以),但是!!!ie浏览器,360兼容模式,不管打包还是没打包,都不能显示,完全没有加载进去数据,如下图
在这里插入图片描述
并且还报错以下未定的错
在这里插入图片描述
在这里插入图片描述
(1)、
查询后发现,是因为IE没有这个方法,不支持sessionStorage,解决的方法是:IE本地调试用cookie,或者用webstrom打开项目,但我确实用的webstorm打开的项目,还是不可以,后来找到解决方法,要把es6转es5

转换语句:npm i babel-preset-es2015
并且在项目的根目录下,修改.babelrc的内容,添加'es2015'

在这里插入图片描述
发现不报未定义的错了,开始报下图的错在这里插入图片描述

安装 npm i classlist-polyfill,并且在base.config.js中,添加'classlist-polyfill'

在这里插入图片描述
然后,npm run dev,居然可以了适配了。

注意: 如果引用了swiper的宝宝,记得要单独安装插件适配IE浏览器哦
因为大家的环境,装的依赖,用的组件等等都不相同,导致遇到的情况可能不一致,如果有其他要注意兼容的地方出现了,欢迎大家指出,多多题意见

  • 33
    点赞
  • 190
    收藏
    觉得还不错? 一键收藏
  • 17
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 17
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值