作者:管理员 历史版本:1 更新时间:2024-09-20 15:09
解决IE版本兼容解决方案【参考】
背景介绍
IBPS平台3.0以上版本框架采用vue-cli3,整体采用语法多为es6为主,本身内置了es6转译es5得方法。但是整体方面对于IE9以上版本得兼容还是存在问题,对此还是需要对IE浏览器做兼容。有些不能自动转译,需手动转译。
现在查阅这里了解vue-cli3兼容方案。
问题一:无法在IE正常加载
1、vue-cli 升级
升级到最新版本(更多代码看具体代码)
2、babel.config 配置
module.exports = {
presets: [
'@vue/cli-plugin-babel/preset'
],
// 允许两种编码引入方式共存,也就是 common 规范与 es6 规范的共存处理
sourceType: 'unambiguous'
}
3、转译element-ui
平台整体UI采用element-ui去实现前端页面的样式渲染,有些组件采用element-ui的帮助类
采用官方方式(该方法不行)
vue.config.js添加一个属性去额外的转译element-ui的文件包
module.exports = {
...
transpileDependencies: ['element-ui'],
...
}
可行办法
自己引入帮助类
替换是有用
4、转译其他不自动转义的第三方库【推荐使用】
transpileDependencies: 默认情况下 babel-loader 会忽略所有 node_modules 中的文件。如果你想要通过 Babel 显式转译一个依赖,可以在这个选项中列出来。
transpileDependencies: [
'signature_pad',
'resize-detector',
'vue-grid-layout',
'fuse.js',
'highlight.js',
'screenfull',
'jsencrypt',
'crypto-js',
'vue-echarts',
'element-ui'
],
5、路由方式改进
采用import 懒加载
6、不支持IE的第三方库
需要降版本
crypto-js 4.0.0-
screenfull 5.2.0-
更多优化看代码
执行上述操作后重启项目,关闭之前打开的IE浏览器,在项目重启完毕之后打开IE浏览器重新打开项目便可。