博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Code Splitting 代码分离
阅读量:6048 次
发布时间:2019-06-20

本文共 1188 字,大约阅读时间需要 3 分钟。

发现问题

这是一个基于 vue-cli 的管理后台项目,由于依赖较多,打包结果如下

图片描述

查找原因

为什么 vendor 体积这么大?

借助 Webpack 的分析工具,看了下各个依赖的体积分布

图片描述

看起来是 Highcharts 和 Element-UI 占了较大体积,那就想办法优化呗

这两个库都提供了按需加载的功能,能有效减小体积,只是刚好这个管理后台项目依赖较多

解决方法

CDN 外链

先把 Highcharts 和 Lodash 通过外链引入

外链引入的资源就不能直接通过 import 来使用,但可以通过 Webpack 的 externals 特性来兼容

import _ from 'lodash'import Highcharts from 'highcharts'console.log([_, Highcharts])

这样配置 Webpack 就知道这两个依赖是外链全局的,不需要打包

externals: {  lodash: '_',  highcharts: 'Highcharts'}

先看看去掉 Highcharts 和 Lodash 的效果

图片描述

vendor 也避免打包了这两个库

图片描述

这种方式适用于不常更新的第三方依赖,采用外链,Element-UI 由于常有新特性更新,我会保持最新版本,所以还是通过 npm 来管理

但是,内网部署咋办

直到有一天,这个管理后台项目要部署到一个内网机器,访问不了外网,那这种方式就走不通了

拆开 vendor

Webpack 默认是将依赖打包成一个文件,这样优点是减少资源请求数,但当依赖增多,体积增大,一个资源的加载速度就会减慢

所以我开始尝试去拆包

new webpack.optimize.CommonsChunkPlugin({  name: 'charts',  chunks: ['vendor'],  minChunks: module => module.resource.indexOf('highcharts') > -1}),new webpack.optimize.CommonsChunkPlugin({  name: 'utils',  chunks: ['vendor'],  minChunks: module => module.resource.indexOf('lodash') > -1}),new webpack.optimize.CommonsChunkPlugin({  name: 'ui',  chunks: ['vendor'],  minChunks: module => module.resource.indexOf('element-ui') > -1})

拆包后的打包结果

图片描述

看看分析工具

图片描述

总结

外链简单粗暴,而拆包可以配合浏览器缓存,每次发布最小化更新资源

转载地址:http://hexex.baihongyu.com/

你可能感兴趣的文章
【小白入门教程】3 分钟搞明白直播中拖动不准的问题
查看>>
It English 每日更新
查看>>
程序员面试揭秘之程序员靠什么途径去美国工作?
查看>>
Install gocode
查看>>
Using Stored Programs with MySQLdb
查看>>
HDU1847 Good Luck in CET-4 Everybody!
查看>>
Bzoj1188 [HNOI2007]分裂游戏
查看>>
python常用数据类型-字符串
查看>>
php之array_column
查看>>
JVM运行时内存结构学习
查看>>
管理维护Replica Sets
查看>>
asp.net core 系列 3 依赖注入服务
查看>>
HashMap 和 HashTable区别
查看>>
git 格式化输出版本信息
查看>>
js 防止重复提交表单
查看>>
日期工具类 DateTools
查看>>
数据结构5.4_m元多项式的表示
查看>>
14. Longest Common Prefix
查看>>
Servlet页面登录的数据库验证程序(一)
查看>>
使用Promise 解决回调地狱
查看>>