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-01-22 22:01:19

    Emscripten Compiler Frontend (emcc)

    The Emscripten Compiler Frontend (emcc) is used to call the Emscripten compiler from the command line. It is effectively a drop-in replacement for a standard compiler like gcc or clang.

  • 2021-01-22 22:21:41

    emcc编译命令介绍

    这个输入文件file,既可以是clang可以编译的C/C++语言,也可以是二进制形式的llvm bitcode或者人类可读形式的llvm assembly文件。

  • 2021-01-22 22:25:51

    How to protect your JS code by WebAssembly

    对于iOS或是Android来说,我们可以将相关的算法通过C/C++进行编写,然后编译为dylib或是so并进行混淆以此来增加破解的复杂度,但是对于前端来说,并没有类似的技术可以使用。当然,自从asm.js及WebAssembly的全面推进后,我们可以使用其进一步增强我们核心代码的安全性,但由于asm.js以及WebAssembly标准的开放,其安全强度也并非想象中的那么美好。

  • 2021-01-24 09:50:16

    UICollectionViewCell cell高度自适应

    本来想使用UICollectionView来作为整体的布局,并且不再使用UITableView,但是发现高度不固定的布局,UICollectionView没啥优势呀,至少我没找到好的方法,从网上看的是,要自定义cell,并且继承preferredLayoutAttributesFittingAttributes