tree?shaking對(duì)打包體積優(yōu)化及作用
背景
大家平時(shí)在查 webpack構(gòu)建體積優(yōu)化 ,可能都會(huì)查到 tree-shaking 這個(gè)東西,很多人看到這個(gè)東西,就會(huì)把它背下來,用來應(yīng)付以后面試官可能會(huì)問到的情況。
但是,又有多少人去真的了解一下 tree-shaking 呢?自己去實(shí)踐一下看 tree-shaking 到底起了哪些作用?對(duì)于我們的打包體積的優(yōu)化又有多少呢?
有啥用?
Tree Shaking
中文含義是搖樹,在webpack中指的是打包時(shí)把無用的代碼搖掉,以優(yōu)化打包結(jié)果。
而webpack5
已經(jīng)自帶了這個(gè)功能了,當(dāng)打包環(huán)境為production
時(shí),默認(rèn)開啟tree-shaking
功能。
實(shí)踐
前置準(zhǔn)備
準(zhǔn)備兩個(gè)文件main.js、util.js
util.js
function a () { console.log('a') } function b () { console.log('b') } export default { a, b }
main.js
import a from './util' // 使用a變量,調(diào)用文件里面的a函數(shù),不使用b函數(shù) console.log(a.a()) console.log('hello world') // 不可能執(zhí)行的代碼 if (false) { console.log('haha') } // 定義了但是沒用的變量 const m = 1
打包
前面說了webpack5
在環(huán)境production
下打包的話,默認(rèn)開啟tree-shaking
,那我們運(yùn)行npm run build
進(jìn)行一下打包,看看打包后的代碼長啥樣:
(()=>{"use strict"; const o=function(){console.log("a")}; console.log(o()) console.log("hello world")} )();
結(jié)論:可以看到打包后,把b函數(shù)、不可能執(zhí)行的代碼、定義未用的變量通通都剔除了,這在一個(gè)項(xiàng)目中,能減少很多的代碼量,進(jìn)而減少打包后的文件體積。
sideEffects
副作用
先來講講一個(gè)東西——副作用
,是什么東西呢?副作用
指的是:除了導(dǎo)出成員之外所做的事情,我舉個(gè)例子,下面的a.js
是沒副作用的,b.js
是有副作用的:
a.js
function console () { console.log('console') } export default { console }
b.js
function console () { console.log('console') } // 這個(gè)就是副作用,會(huì)影響全局的數(shù)組 Array.prototype.func = () => {} export default { console }
有無副作用的判斷,可以決定tree-shaking
的優(yōu)化程度,舉個(gè)例子:
- 我現(xiàn)在引入
a.js
但是我不用他的console
函數(shù),那么在優(yōu)化階段我完全可以不打包a.js
這個(gè)文件。 - 我現(xiàn)在引入
b.js
但是我不用他的console
函數(shù),但是我不可以不打包b.js
這個(gè)文件,因?yàn)樗懈弊饔茫荒懿淮虬?/li>
sideEffects的使用
sideEffects
可以在package.json
中設(shè)置:
// 所有文件都有副作用,全都不可 tree-shaking { "sideEffects": true } // 沒有文件有副作用,全都可以 tree-shaking { "sideEffects": false } // 只有這些文件有副作用, // 所有其他文件都可以 tree-shaking, // 但會(huì)保留這些文件 { "sideEffects": [ "./src/file1.js", "./src/file2.js" ] }
優(yōu)化體積
當(dāng)我把sideEffects
設(shè)置成true
之后,整個(gè)打包體積增加了100k
,說明默認(rèn)的false
還是有用的。。
以上就是tree shaking對(duì)打包體積優(yōu)化及作用的詳細(xì)內(nèi)容,更多關(guān)于tree shaking打包體積優(yōu)化的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序支付之c#后臺(tái)實(shí)現(xiàn)方法
這篇文章主要介紹了微信小程序支付之c#后臺(tái)實(shí)現(xiàn)方法的相關(guān)資料,希望通過本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10基于JavaScript ES新特性let與const關(guān)鍵字
這篇文章主要介紹了基于JavaScript ES新特性let與const關(guān)鍵字,let是ECMAScript 2015新增的一個(gè)關(guān)鍵字,用于聲明變量,const關(guān)鍵字用于聲明一個(gè)常量,更多詳細(xì)內(nèi)容,請需要的小伙伴參考下面文章的介紹,希望對(duì)你有所幫助2021-12-12微信小程序 基礎(chǔ)知識(shí)css樣式media標(biāo)簽
這篇文章主要介紹了微信小程序 基礎(chǔ)知識(shí)css樣式media標(biāo)簽的相關(guān)資料,需要的朋友可以參考下2017-02-02