学习笔记——vite 打包构建优化之tree shaking

vite 打包构建优化

开发环境优化
生产环境优化

tree shaking 解释说明

1、代码引入但是没有使用 对应函数
1.1、 如果代码中有副作用

副作用的理解: 如修改全局变量、修改 DOM、执行日志等

js 复制代码
/* 本身就是副作用 */
console.log("side effect");
/* 这种/ 上面描述这种 副作用 我们可以通过 特殊方式进行处理 来让他们打包进入我们的最终产物中 */
window.abc = "hello";
1.2、解决方案

🟢 1.2.1、 通过 package.json 中 配置 sideEffects

json 复制代码
// package.json 中 配置 sideEffects 为false 表示 代码中没有副作用  为 true 表示 代码中有副作用
"sideEffects": false
json 复制代码
"sideEffects": true

🟢 1.2.2、通过添加注释 说明 代码中没有副作用

js 复制代码
/*#__PURE__*/ console.log(
  "我本身是有副作用的 但是你给我加了这个注释 那我就没有副作用了"
);
console.log("我本身是有副作用的 你没有给我加注释 所以我就是有副作用的");
js 复制代码
console.log("我本身是有副作用的 但是你给我加了这个注释 那我就没有副作用了");

console.log("我本身是有副作用的 你没有给我加注释 所以我就是有副作用的");

🟢 1.2.3、

  • 🟢 1.2、 如果代码中没有副作用

    js 复制代码
    export function square(x: any) {
      const a = "我是过节";
      return x * x + a;
    }
    export function cube(x: any) {
      return x * x * x;
    }
js 复制代码
如果只是在其他模块引入 但是没有使用 里面的函数 则不会将此函数打包进最终的代码
  • 🔴 3、遇到的问题 lodash 引用一个但是 打包产物是整个产物

    • 🟢 3.1、
js 复制代码
/* 错误的引入方式 */
import * as _ from "lodash";
/* 1. 使用按需导入 在我的项目中 占用 5% */
import shuffle from "lodash/shuffle"; // 只引入 shuffle 函数
/* 2. 使用 lodash-es(ES Module 版本) 占用 3% */
import { shuffle } from "lodash-es"; // 支持按需导入
bash 复制代码
 npm install lodash-es
相关推荐
RainCity1 天前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
LinXunFeng9 天前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
通信小呆呆13 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
H__Rick13 天前
自动对焦学习-3
人工智能·学习·计算机视觉
Daisy Lee13 天前
量化学习-第1章-什么是量化金融
学习·金融·datawhale
Alsn8613 天前
等待学习-学习目录:Docker 容器安全攻防
学习·安全·docker
YM52e13 天前
买菜计算器小应用 - HarmonyOS ArkUI 开发实战-PC版本
学习·华为·harmonyos·鸿蒙·鸿蒙系统
小雨下雨的雨13 天前
HarmonyOS ArkUI训练营入门-组件掌握系列-Animation 动画效果实现-PC版本
学习·华为·harmonyos·鸿蒙
闪闪发亮的小星星13 天前
高斯光以及高斯光公式解释
笔记
cqbzcsq13 天前
CellFlow虚拟细胞论文阅读
论文阅读·人工智能·笔记·学习·生物信息