插件导致ECharts被全量引入的坑示例解析


Posted in Javascript onSeptember 23, 2022

正文

ECharts作为一个图标库已经被大家广泛使用,它提供了各式各样的图表类型,但是在我们日常使用中可能只会用到其中的某几个图表类型,常用的基本就是柱状图,条线图,及中国地图插件用来表示全国各地的数据这些,所以在我们使用echarts的时候首先需要考虑的是按需引入,避免把整个库都打包进去,echarts的整个打包体积还是相当可观的?。

以下仅针对 echarts@v4 版本

按需引入的问题

以下是正常的按需引入echarts的一些图标组件,我们从echarts/lib下面按需引入我们需要的图标,对于lib下的组件没有任何问题:

import echarts from 'echarts/lib/echarts'
import 'echarts/lib/chart/line'
import 'echarts/lib/chart/pie'
import 'echarts/lib/chart/bar'
import 'echarts/lib/chart/map'
import 'echarts/lib/chart/scatter'
import 'echarts/lib/component/tooltip'
// ...

接下来我们再看下当我们需要用中国地图的时候:

import 'echarts/map/js/china.js'

问题分析

我们只需像上面一样直接引入china.js即可使用中国地图,看起来似乎使用上也没啥问题,那我们就用webpack-bundle-analyzer来看下打包出来的实际情况:

插件导致ECharts被全量引入的坑示例解析

从图中我们可以看到,有2处地方都出现了echarts,这和我们的预期完全不符,我们希望的是echarts/lib下通用的直接打到vendor.js里去,然后在某个页面里面我们用到了china map这个只跟着路由异步加载进来(如上图右侧紫色区域),但是异步加载的js里也出现了完整的echarts库,明显跟vendor.js里重复了,这就?了,我们明明只引入了china.js,为啥会整个引入,还被重复引入到了2个文件里。

这个时候我们就从china.js入手,看看这个文件里面到底干了什么事情:

插件导致ECharts被全量引入的坑示例解析

我们进入china.js里面,仔细观察会发现上图中第26行,直接require('echarts')了整个库,这就相当于我们应用代码再怎么按需引入,只要你用了china插件,整个echarts还是被全量引入了进来,然后上面webpack-bundle-analyzer图在多处出现的原因我们就可以推出是因为我们引用代码跟china.js里引入的路径不一样从而导致了chunk那个js被重复引入了echarts完整库:

// 应用代码只映入了核心库
import echarts from 'echarts/lib/echarts'
// china.js require了整个echarts
require('echarts')

解决方案

OK,通过上面分析我们已经发现问题所在,那么我们可以有哪些办法来解决这样的问题呢(让echarts官方去改这个问题似乎不是很现实?),以下例举了几种常用的潜在解决方案,大家可根据自己项目的实际情况使用(有更好办法的大佬们可在评论里指出?):

  • webpack的alias,对于直接引入echarts的地方,替换成echarts/lib/echarts,但是这样可能会对其他地方全量引入用到的图表,但是你又没有手动按需引入相应的图表就可能报错了
  • 通过webpack.NormalModuleReplacementPlugin插件或者alias直接替换echarts/map/js/china.js的引用,换成自己的一个文件,文件可以copychina.js,然后把require('echarts')换掉,见下面一点
  • copyregisterMap方法内容,直接引用自己的这个文件?:

插件导致ECharts被全量引入的坑示例解析

优化后我们再用webpack-bundle-analyzer看下打包情况,可以发现只剩下一个vendor里的echarts了,符合我们的预期:

插件导致ECharts被全量引入的坑示例解析

以上就是使用echarts插件时发现的一些引入问题,大家在使用第三方库的时候,特别是一些大的库时还是多留意下打包出来的结果是不是跟预期是一样的,很有可能一个小的引入写法默默地导致了整个库都被引入了?。

更多关于插件全量引入ECharts坑的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
用javascript将数据库中的TEXT类型数据动态赋值到TEXTAREA中
Apr 20 Javascript
javascript 浏览器判断 绑定事件 arguments 转换数组 数组遍历
Jul 06 Javascript
Ext GridPanel加载完数据后进行操作示例代码
Jun 17 Javascript
Javascript中封装window.open解决不兼容问题
Sep 28 Javascript
Bootstrap的图片轮播示例代码
Aug 31 Javascript
JS基于ocanvas插件实现的简单画板效果代码(附demo源码下载)
Apr 05 Javascript
js实现键盘自动打字效果
Dec 23 Javascript
浅谈ES6新增的数组方法和对象
Aug 08 Javascript
微信小程序结合mock.js实现后台模拟及调试
Mar 28 Javascript
详解ES6 Promise的生命周期和创建
Aug 18 Javascript
浅析js实现网页截图的两种方式
Nov 01 Javascript
JS正则表达式验证端口范围(0-65535)
Jan 06 Javascript
TypeScript实用技巧 Nominal Typing名义类型详解
Sep 23 #Javascript
Moment的feature导致线上bug解决分析
Sep 23 #Javascript
js 实现Material UI点击涟漪效果示例
Sep 23 #Javascript
js 实现验证码输入框示例详解
Sep 23 #Javascript
TypeScript 内置高级类型编程示例
Sep 23 #Javascript
详解Anyscript开发指南绕过typescript类型检查
Sep 23 #Javascript
js基于div丝滑实现贝塞尔曲线
Sep 23 #Javascript
You might like
PHP 选项及相关信息函数库
2006/12/04 PHP
PHP 无限分类三种方式 非函数的递归调用!
2011/08/26 PHP
PHP定时执行计划任务的多种方法小结
2011/12/19 PHP
php smarty模板引擎的6个小技巧
2014/04/24 PHP
PHP滚动日志的代码实现
2015/06/10 PHP
Zend Framework教程之Zend_Helpers动作助手ViewRenderer用法详解
2016/07/20 PHP
php抛出异常与捕捉特定类型的异常详解
2016/10/26 PHP
不用ajax实现点击文字即可编辑的方法
2007/12/16 Javascript
jQuery ajax cache缓存问题
2010/07/01 Javascript
JQuery 动态生成Table表格实例代码
2016/12/02 Javascript
JS 循环li添加点击事件 (闭包的应用)
2016/12/10 Javascript
利用JS制作万年历的方法
2017/08/16 Javascript
Angular入口组件(entry component)与声明式组件的区别详解
2018/04/09 Javascript
react.js组件实现拖拽复制和可排序的示例代码
2018/08/20 Javascript
vue 项目接口管理的实现
2019/01/17 Javascript
基于node.js实现爬虫的讲解
2019/02/18 Javascript
微信小程序中转义字符的处理方法
2019/03/28 Javascript
[03:22]DAC最前线(第二期)—DOTA2亚洲邀请赛主赛场周边及线路探访
2015/01/24 DOTA
[01:58]最残酷竞争 2016国际邀请赛中国区预选赛积分循环赛回顾
2016/06/28 DOTA
[01:00:30]完美世界DOTA2联赛循环赛 Inki vs Matador BO2第二场 10.31
2020/11/02 DOTA
初学Python函数的笔记整理
2015/04/07 Python
Python微信公众号开发平台
2018/01/25 Python
在python中利用KNN实现对iris进行分类的方法
2018/12/11 Python
3行Python代码实现图像照片抠图和换底色的方法
2019/10/10 Python
python爬虫基础知识点整理
2020/06/02 Python
Django web自定义通用权限控制实现方法
2020/11/24 Python
Stefania Mode英国:奢华设计师和时尚服装
2017/10/23 全球购物
汇科协同Java笔试题
2012/03/31 面试题
恶搞卫生巾广告词
2014/03/18 职场文书
5s推行计划书
2014/05/06 职场文书
广告艺术设计专业自荐书
2014/07/08 职场文书
2014年乡镇工作总结
2014/11/21 职场文书
安全生产隐患排查制度
2015/08/05 职场文书
Nginx+Tomcat实现负载均衡、动静分离的原理解析
2021/03/31 Servers
nginx配置文件使用环境变量的操作方法
2021/06/02 Servers
「月刊Comic Alive」2022年5月号封面公开
2022/03/21 日漫