最近答疑群里面有同学反馈说G6不支持IE,官网上的Demo在IE上完全打不开,对于这样对问题,我们有考虑过怎么处理,最终没有选择内部处理,具体原因自行脑补。

下面针对@vue/cli、umi、create-react-app搭建的项目给出一些解决方案,务必确保在没有引入G6时你的项目可以正常运行在IE上, 我相信如果项目框架是你自己搭建的,那么IE兼容性问题对你来说完全不是问题,更确切的说应该是依赖的兼容性问题怎么解决

类似如下错误。
9B7EDCB4-D317-4FB5-814D-68F58817ADD4.png

vue/cli

案例是基于@vue/cli(V: 4.0.5),如果你的版本是3.x的话可能写法上会有出入,@vue/cli怎么解决依赖兼容性问题呢?
遇到问题首先想到的是官网,没错,先看看官网上有没有类似的教程,从官网上我们定位到浏览器兼容性,如下

7AEAC95F-6626-476E-8C63-830852883FC6.png

从文章中我们貌似已经找到了问题的答案,我们需要新建vue.config.js文件(和package.json同一目录),在里面添加transpileDependencies选项,

6CDAA5DF-2206-4749-B5BD-C8EB3D13527D.png

该选项默认值是[],说明会忽略掉所有掉node_modules文件,不会对node_modules里面对文件做Babel,我们需要做的就是把我们希望Babel的文件加入即可,代码如下,需要注意的是我们加入的依赖不需要包含node_modules,用包名(@antv/g6)即可,因为@vue/cli会自动添加前缀node_modules。 还需要注意 @antv/g6必须和package.json里面的一致,安装依赖的时候首选npm,如果你用yarn、cnpm等安装,需要确保node_modules里面的包名没有被更改。

  1. module.exports = {
  2. transpileDependencies: ["@antv/g6"]
  3. };

好了,我们打开IE11看看结果吧。
DF84211F-8B5E-4100-9048-86BB445DF28E.png

最开始的那个报错解决了,但咋出现了新问题呢,别急,先用chrome浏览器看看,发现问题是一样的,添加完transpileDependencies兼容性问题是没有了,但出了个新错误。再次查看官网,并没有相关文章,那就直接移步issue吧,经过一番查找,我们找到如下解决方案,在babel.config.js里面添加上sourceType: “unambiguous”,具体含有可以官网查阅。

  1. module.exports = {
  2. sourceType: "unambiguous",
  3. presets: ["@vue/cli-plugin-babel/preset"]
  4. };

再次编译,

F4680A19-5EB7-43DE-97C0-E86CAB824973.png

到此,完美解决问题。

create-react-app

如果你使用create-react-app(V: 3.0.0)初始化项目,那么恭喜你,create-react-app已经内置了依赖兼容性的处理方案,你只需要配置项目自身的兼容性问题即可,配置有多种方式,可参考

github:https://github.com/lxfu/react-g6
eg:
448C42C7-C55A-452E-847D-DC1C1F9955B1.png

当然,也许你想看看内部是怎么处理的,那就执行npm run eject 或 yarn run eject吧,这样就能暴露create-react-app的内置配置了,这个操作是不可逆的。 内置配置如下
EA6D3C17-BD59-45CA-9B86-F581CCF278A3.png

umi

如果你使用的是umi,再次恭喜你,umi不仅内置了依赖兼容性方案,而且配置简单,如果有任何问题,你可以在答疑群里面@云谦大佬。
github:https://github.com/lxfu/umi-g6

  1. export default {
  2. targets: {
  3. ie: 11,
  4. },
  5. };

总结

文章比较短,列举也不全,希望看了该文章的你知道怎么去解决依赖兼容性问题。