webpack用externals优化echarts

2020-01-14 01:08:19

参考地址 一次webpack 的externals配置带来的优化体验

externals官方解释:


防止将某些 import 的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖(external dependencies)。


1.优化前


使用echarts的一个项目,使用npm run build 打包以后还有6m左右的大小,如下:



这里打包以后文件明显过大,可能会造成用户体验差。


2.优化


考虑到可能是因为引入的echarts过大,打包时将echarts打包进去了引起的。externals可以将echars脱离webpack打包,可以用来解决这个问题。


2.1 在webpack配置文件中配置externals。


在webpack.base.conf.js文件中配置外部扩展externals,如下:


 externals: {

   echarts: 'echarts',

  },

1

2

3

如下图:



2.2 在模板文件index.html文件中使用cdn引入echarts


使用前需要在模板文件index.html文件中使用cdn引入echarts,否则会报echartsundefined的错误。如下:


<script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts.min.js"></script>

1


2.3 在需要使用echarts的地方直接使用


配置外部扩展externals以后,在vue文件中就不需要再使用import或者require引入echarts了,可以直接使用,比如初始化图表就可以直接使用this.$echarts.init()。如下:




2.3 再次打包


再次使用cnpm run build打包,此时dist文件夹已经只有1m多了,大小直接减小了5M,效果立竿见影啊。如下:



打包报告:


打包的时间也有缩短,只有12ms左右,





  • 2021-04-15 10:11:17

    Puppeteer拦截修改返回值

    page.setRequestInterception(true)拦截器的使用方法和场景 现附上Puppeteer的Api的链接https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md

  • 2021-04-15 10:32:18

    怎么给 headless chrome添加cookies

    In puppeter you have access to the session cookies through page.cookies(). So once you log in, you could get every cookie and save it in a json file:

  • 2021-04-15 10:51:21

    如何通过Devtools协议拦截和修改Chrome响应数据

    在日常研究中,我们经常碰到大量JavaScript代码,我们首先要深入分析才能了解这些代码的功能及具体逻辑。这些代码代码可能会被恶意注入到页面中,可能是客户送过来需要我们帮忙分析的脚本,也可能是我们的安全团队在网页上找到的引用了我们服务的某些资源。这些脚本通常代码量不大、经过混淆处理,并且我们总是需要经过多层修改才能继续深入分析。

  • 2021-04-19 10:54:39

    block和delegate的区别

    代理 可读性高 大部分可以属性 block 写的代码少 一般作为参数 通知 占用资源

  • 2021-04-19 11:00:23

    浅谈block和delegate的使用

    委托是协议的一种,顾名思义,就是委托他人帮自己去做事。委托是给一个对象提供机会对另一个对象中的变化做出反应或者影响另一个对象的行为。其基本思想是:两个对象协同解决问题,并且打算在广泛的情形中重用。委托指向另一个对象(即它的委托)的引用,并在关键时刻给委托发消息。消息可能只是通知委托发生了某件事情,给委托提供机会执行额外的处理,或者消息可能要求委托提供一些关键的信息以控制所发生的事情。委托的作用主要有两个,一个是传值,一个是传事件。

  • 2021-04-19 11:36:44

    iOS 组件实现方案

    什么才是好架构,为什么要组件,组件设计的优点

  • 2021-04-25 09:53:18

    android debug速度特别慢有时候卡住

    一直提示定在 Starting LLDB server。可能的原因是 Android Studio编译速度太慢了,就会一直卡在Starting LLDB server。可以通过设置 Run/Debug Configurations ——> Debugger ——> Debug type 为 Java 跳过 C/C++的调试,起码实现对 Java 程序的调试