学习笔记——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
相关推荐
charlie114514191几秒前
嵌入式现代C++:何时用 C++、用哪些 C++ 特性(折中与禁用项)
开发语言·c++·笔记·学习
YJlio2 小时前
Windows Sysinternals 文件工具学习笔记(12.11):综合实战——从磁盘告警到文件替换的一条龙排障
windows·笔记·学习
旖旎夜光4 小时前
Linux(4)(下)
linux·学习
敲敲了个代码7 小时前
从硬编码到 Schema 推断:前端表单开发的工程化转型
前端·javascript·vue.js·学习·面试·职场和发展·前端框架
沐风听雨_A9 小时前
雄迈IP摄像头配置笔记
笔记
我命由我123459 小时前
SVG - SVG 引入(SVG 概述、SVG 基本使用、SVG 使用 CSS、SVG 使用 JavaScript、SVG 实例实操)
开发语言·前端·javascript·css·学习·ecmascript·学习方法
沐风听雨_A11 小时前
有人串口转Wifi模块配置笔记
笔记
Fern_blog11 小时前
鸿蒙学习之路
学习
小智RE0-走在路上12 小时前
Python学习笔记(11) --数据可视化
笔记·python·学习
么么...14 小时前
在 Ubuntu 上安装 Docker 并部署 MySQL 容器
linux·运维·经验分享·笔记·mysql·ubuntu·docker