webpack4.15.1 学习笔记(四) — Tree shaking
Tree shaking
本质上为了消除无用的js代码,减少加载文件体积的方式,使其整体执行时间更短。无用的代码,又有另外一种叫法:Dead Code:
- 代码不可到达,不会执行,如不可能进入的分支,return 之后的语句等
- 代码中的某个变量只有写,而没有读操作
Tree Shaking 的执行环境宿主一般是Node,而不是浏览器,且必须遵循ES6 Module规范,因为 ES6 Module 可以静态分析,可以推导出变量和导入依赖变量的引用关系。
原理
Tree-Shaking实现步骤
- 标记出模块导出值哪些没有被用过,标记功能需要配置 optimization.useExports = true 开启
- Make 阶段,收集导出变量并记录到模块依赖图ModuleGraph 变量中。
- Seal 阶段,遍历ModuleGraph 标记模块导出变量有没有被使用
- 生成产物时,若变量没有被其他模块使用时则删除对应的导出语句
- 使用Terser删除掉没有被用到的导出语句
标记效果
webpack 负责对代码进行标记,把import & export 标记为3类:
- 所有 import 标记为
/\* harmony import \*/; - 被使用过的 export 标记为
/\* harm export([type])\*/; - 未被使用过的 export 标记为
/\* unused harmony export [FuncName] \*/,其中[FuncName] 为export 的方法名称
副作用代码不可被删除
副作用是函数式编程的一个概念,是指当调用函数时,除了返回函数值之外,还会对调用函数产生附加的影响。比如console,读取和修改外部变量,导入css文件,引入Polyfill 等
会导致document.title 没有成功被设置导致出现bug。const setTitle = ()=>{
document.title = "tree shaking learn";
}
const a = setTitle(); // 虽然a变量没有被其他地方使用,但由于副作用,如果将其删除,会导致document.title 没有成功被设置导致出现bug。
如何实现 Tree shaking 的几种方法
- 执行
webpack --mode development时,打包后的代码并没有压缩且包含注释,添加--optimize-minimize命令进行压缩后。将打包后的代码压缩至一行,并删除了未引用的代码,可以把这串命令放入 package.json 的 scripts 字段中执行。 - 当没有设置 webpack mode模式时。会提示一行黄字 The 'mode' option has not been set, webpack will fallback to 'production' for this value. 因此该配置在mode=production时默认为true,也就是说webpack生产模式中,自动开启了Tree Shaking这个功能,可以直接 执行
webpack命令进行打包。 - 其实
--optimize-minimize的底层实现是一个插件UglifyJsPlugin,参考其他教程直接在webpack.config.js里配置,运行后报错,原因是在新版本的webpack中,移除了这个插件,因此该方法不可行。RemovedPluginError: webpack.optimize.UglifyJsPlugin has been removed, please use config.optimization.minimize instead.
const webpack = require('webpack');
module.exports = {
// ...
plugins:[
new webpack.optimize.UglifyJsPlugin(), // RemovedPluginError webpack.optimize.UglifyJsPlugin has been removed
],
}
- Tree Shaking并不是 webpack 的某个配置选项,而是
一组功能搭配使用后的优化效果。并且在生产模式production下自动使用。根据上述RemovedPluginError报错提示,配置optimization中的usedExports和minimize优化功能实现Tree Shaking。
module.exports = {
// ...
optimization: {
usedExports: true, // 表示在输出结果中模块只导出外部使用了的成员。
minimize: true, // 开启代码压缩优化, 删除注释、删除没有用到的代码、删除空白、替换变量名为简短的名称等,
},
};
webpack打包后,将每个模块放到一个函数中,包含成员的定义和成员的导出。
usedExports 可以标记模块导出的成员是否被外部使用,从而在打包结果中,不导出未使用的成员。标记打包后表现为:包裹模块的函数中保留定义这些成员的代码,但是移除导出它们的代码,并添加注释 /* unused harmony export */。
而函数中没有了导出它们的代码,也就表示这些成员未使用,那定义它们的代码也没有了意义,minimize就会将这些未使用的定义成员的垃圾代码一并删除。
usedExports 负责标记「枯树叶、枯树枝」
minimize 负责「摇掉」它们
总结
- Tree Shaking 用于减小文件体积
- 其工作流程是先标记,后删除
- 代码必须遵循 ES Module 规范
- 删除代码失灵很可能因出现副作用代码导致
webpack4.15.1 学习笔记(四) — Tree shaking的更多相关文章
- 官网实例详解-目录和实例简介-keras学习笔记四
官网实例详解-目录和实例简介-keras学习笔记四 2018-06-11 10:36:18 wyx100 阅读数 4193更多 分类专栏: 人工智能 python 深度学习 keras 版权声明: ...
- kvm虚拟化学习笔记(四)之kvm虚拟机日常管理与配置
KVM虚拟化学习笔记系列文章列表----------------------------------------kvm虚拟化学习笔记(一)之kvm虚拟化环境安装http://koumm.blog.51 ...
- go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用)
目录 go微服务框架kratos学习笔记四(kratos warden-quickstart warden-direct方式client调用) warden direct demo-server gr ...
- Java IO学习笔记四:Socket基础
作者:Grey 原文地址:Java IO学习笔记四:Socket基础 准备两个Linux实例(安装好jdk1.8),我准备的两个实例的ip地址分别为: io1实例:192.168.205.138 io ...
- C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻
前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...
- IOS学习笔记(四)之UITextField和UITextView控件学习
IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...
- java之jvm学习笔记四(安全管理器)
java之jvm学习笔记四(安全管理器) 前面已经简述了java的安全模型的两个组成部分(类装载器,class文件校验器),接下来学习的是java安全模型的另外一个重要组成部分安全管理器. 安全管理器 ...
- Learning ROS for Robotics Programming Second Edition学习笔记(四) indigo devices
中文译著已经出版,详情请参考:http://blog.csdn.net/ZhangRelay/article/category/6506865 Learning ROS for Robotics Pr ...
- Typescript 学习笔记四:回忆ES5 中的类
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- ES6学习笔记<四> default、rest、Multi-line Strings
default 参数默认值 在实际开发 有时需要给一些参数默认值. 在ES6之前一般都这么处理参数默认值 function add(val_1,val_2){ val_1 = val_1 || 10; ...
随机推荐
- 当面试官问出“Unsafe”类时,我就知道这场面试废了,祖坟都能给你问出来!
一.写在开头 依稀记得多年以前的一场面试中,面试官从Java并发编程问到了锁,从锁问到了原子性,从原子性问到了Atomic类库(对着JUC包进行了刨根问底),从Atomic问到了CAS算法,紧接着又有 ...
- Android 13 - Media框架(13)- OpenMax(一)
关注公众号免费阅读全文,进入音视频开发技术分享群! 这一节我们将了解Android OpenMax框架,该框架了解完成之后,我们会再回过头去了解 ACodec,将 MediaCodec - ACode ...
- 解决老旧电脑在win7中浏览器访问https网站出现的Let‘sEncrypt证书过期的问题
原因LetsEncrypt证书未过期,但是其顶级ca根证书 "DST Root CA X3"在2021-09-01过期了,老旧设备上的win系统会被影响到. 解决步骤下载三张Let ...
- 鸿蒙极速入门(一)-HarmonyOS简介
1.华为官网介绍 2.OpenHarmony开源项目 3.技术架构 内核层 内核子系统:采用多内核(Linux内核或者LiteOS)设计,支持针对不同资源受限设备选用适合的OS内核 驱动子系统:驱动框 ...
- nginx37条优化
nginx优化: 1. cpu:核心配置 方法1: worker_processes auto; 自动调用[推荐] 方法2: worker_processes 4; 手工配置 检查CPU核心:yum ...
- 8.15考试总结(NOIP模拟40)[送花·星空·零一串]
我只对现实世界绝望过,却未对自己绝望过! T1 送花 解题思路 线段树维护序列. 我们暴力枚举右端点,用线段树搞出当前右端点的最优的左端点的值. 假设当前扫到的右端点是 r ,颜色是 col. 这种颜 ...
- 7.17考试总结(NOIP模拟18)[导弹袭击·炼金术士的疑惑·老司机的狂欢]
问灵十三载,等一不归人. 前言 这回考试全靠 T2 了,别的基本上没分(菜) 总感觉最近进度有亿点快,每天都在补坑,每天都在留坑.... T1 导弹袭击 解题思路 因为这个题的两种长度是不一定的,因此 ...
- [吐槽]困扰了1周的API调用失败问题的原因是使用了加密DNS
参考API的官方文档使用postman测试了一下,导入了百度提供的postman环境配置文件,粘贴提供的预处理代码后直接发起请求,响应里提示 "signature is empty" ...
- react css-in-js
CSS-in-JS是一种技术,而不是一个具体的库实现.简单来说CSS-in-JS就是将应用的CSS样式写在JavaScript文件里面,而不是独立为一些css,scss或less之类的文件,这样你就可 ...
- HTML 使用动态脚本
这个 HTML 图片框架 这个HTML支持的脚本属于动态的插件形式的程序 用分段数方式实现动画 1定时器 2函数 计算机有四则运算加减乘除 还有一个是 ^ (shift + 6这个符号是余数,8^3是 ...