序
最近答疑群里面有同学反馈说G6不支持IE,官网上的Demo在IE上完全打不开,对于这样对问题,我们有考虑过怎么处理,最终没有选择内部处理,具体原因自行脑补,G6只是一个例子,其它插件同样适用**。**
下面针对@vue/cli、umi、create-react-app搭建的项目给出一些解决方案,务必确保在没有引入G6时你的项目可以正常运行在IE上, 我相信如果项目框架是你自己搭建的,那么IE兼容性问题对你来说完全不是问题,更确切的说应该是依赖的兼容性问题怎么解决。
类似如下错误。
vue/cli
本案例是基于@vue/cli(V: 4.0.5),如果你的版本是3.x的话可能写法上会有出入,@vue/cli怎么解决依赖兼容性问题呢?
遇到问题首先想到的是官网,没错,先看看官网上有没有类似的教程,从官网上我们定位到浏览器兼容性,如下
从文章中我们貌似已经找到了问题的答案,我们需要新建vue.config.js文件(和package.json同一目录),在里面添加transpileDependencies选项,
该选项默认值是[],说明会忽略掉所有掉node_modules文件,不会对node_modules里面对文件做Babel,我们需要做的就是把我们希望Babel的文件加入即可,代码如下,需要注意的是我们加入的依赖不需要包含node_modules,用包名(@antv/g6)即可,因为@vue/cli会自动添加前缀node_modules。 还需要注意 @antv/g6必须和package.json里面的一致,安装依赖的时候首选npm,如果你用yarn、cnpm等安装,需要确保node_modules里面的包名没有被更改。
module.exports = {
transpileDependencies: ["@antv/g6"]
};
好了,我们打开IE11看看结果吧。
最开始的那个报错解决了,但咋出现了新问题呢,别急,先用chrome浏览器看看,发现问题是一样的,添加完transpileDependencies兼容性问题是没有了,但出了个新错误。再次查看官网,并没有相关文章,那就直接移步issue吧,经过一番查找,我们找到如下解决方案,在babel.config.js里面添加上sourceType: “unambiguous”,具体含有可以官网查阅。
module.exports = {
sourceType: "unambiguous",
presets: ["@vue/cli-plugin-babel/preset"]
};
再次编译,
到此,完美解决问题。
create-react-app
如果你使用create-react-app(V: 3.0.0)初始化项目,那么恭喜你,create-react-app已经内置了依赖兼容性的处理方案,你只需要配置项目自身的兼容性问题即可,配置有多种方式,可参考。
github:https://github.com/lxfu/react-g6
eg:
当然,也许你想看看内部是怎么处理的,那就执行npm run eject 或 yarn run eject吧,这样就能暴露create-react-app的内置配置了,这个操作是不可逆的。 内置配置如下
umi
如果你使用的是umi,再次恭喜你,umi不仅内置了依赖兼容性方案,而且配置简单,如果有任何问题,你可以在答疑群里面@云谦大佬。
github:https://github.com/lxfu/umi-g6
export default {
targets: {
ie: 11,
},
};
总结
文章比较短,列举也不全,希望看了该文章的你知道怎么去解决依赖兼容性问题。