欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

tree?shaking對(duì)打包體積優(yōu)化及作用

 更新時(shí)間:2022年07月06日 11:41:16   作者:Sunshine_Lin  
這篇文章主要為大家介紹了tree?shaking對(duì)打包體積優(yōu)化及作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

背景

大家平時(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)文章

  • Google 地圖疊加層實(shí)例講解

    Google 地圖疊加層實(shí)例講解

    本文主要介紹Google 地圖疊加層,這里幫大家整理了Google地圖疊加層一些實(shí)用代碼并詳細(xì)介紹了相關(guān)知識(shí),有需要的小伙伴可以參考下
    2016-08-08
  • JavaScript的單線程和異步詳細(xì)

    JavaScript的單線程和異步詳細(xì)

    這篇文章要給大家分享的是JavaScript的單線程和異步,其實(shí)單線程和異步確實(shí)不能同時(shí)成為一個(gè)語言的特性,js選擇了成為單線程的語言,所以它本身不可能是異步的,但js宿主環(huán)境是多線程,宿主環(huán)境通過某種方式使js具備了異步屬性,下面就來具體介紹,需要的朋友可以參考一下
    2021-10-10
  • 微信小程序支付之c#后臺(tái)實(shí)現(xià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)鍵字

    這篇文章主要介紹了基于JavaScript ES新特性let與const關(guān)鍵字,let是ECMAScript 2015新增的一個(gè)關(guān)鍵字,用于聲明變量,const關(guān)鍵字用于聲明一個(gè)常量,更多詳細(xì)內(nèi)容,請需要的小伙伴參考下面文章的介紹,希望對(duì)你有所幫助
    2021-12-12
  • 微信小程序 常用工具類詳解及實(shí)例

    微信小程序 常用工具類詳解及實(shí)例

    這篇文章主要介紹了微信小程序 常用工具類詳解及實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • 微信小程序 上傳頭像的實(shí)例詳解

    微信小程序 上傳頭像的實(shí)例詳解

    這篇文章主要介紹了微信小程序 上傳頭像的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下
    2017-10-10
  • JS前端白屏前世今生及解決方式

    JS前端白屏前世今生及解決方式

    這篇文章主要為大家介紹了JS前端白屏前世今生及解決方式案例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • js簡單封裝監(jiān)聽快捷鍵對(duì)象示例及使用

    js簡單封裝監(jiān)聽快捷鍵對(duì)象示例及使用

    這篇文章主要為大家介紹了js簡單封裝監(jiān)聽快捷鍵對(duì)象及使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • 微信小程序 基礎(chǔ)知識(shí)css樣式media標(biāo)簽

    微信小程序 基礎(chǔ)知識(shí)css樣式media標(biāo)簽

    這篇文章主要介紹了微信小程序 基礎(chǔ)知識(shí)css樣式media標(biāo)簽的相關(guān)資料,需要的朋友可以參考下
    2017-02-02
  • JS前端繪圖canvas模糊問題示例高清圖解

    JS前端繪圖canvas模糊問題示例高清圖解

    這篇文章主要為大家介紹了JS前端繪圖canvas模糊問題示例高清圖解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評(píng)論