溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

tree?shaking對打包體積優化及作用實例分析

發布時間:2022-07-06 13:40:26 來源:億速云 閱讀:135 作者:iii 欄目:開發技術

這篇“tree shaking對打包體積優化及作用實例分析”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“tree shaking對打包體積優化及作用實例分析”文章吧。

有啥用?

Tree Shaking中文含義是搖樹,在webpack中指的是打包時把無用的代碼搖掉,以優化打包結果。

webpack5已經自帶了這個功能了,當打包環境為production時,默認開啟tree-shaking功能。

實踐

前置準備

準備兩個文件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變量,調用文件里面的a函數,不使用b函數
console.log(a.a())
console.log('hello world')
// 不可能執行的代碼
if (false) {
  console.log('haha')
}
// 定義了但是沒用的變量
const m = 1

打包

前面說了webpack5在環境production下打包的話,默認開啟tree-shaking,那我們運行npm run build進行一下打包,看看打包后的代碼長啥樣:

(()=>{"use strict";
const o=function(){console.log("a")};
console.log(o())
console.log("hello world")}
)();

結論:可以看到打包后,把b函數、不可能執行的代碼、定義未用的變量通通都剔除了,這在一個項目中,能減少很多的代碼量,進而減少打包后的文件體積。

sideEffects

副作用

先來講講一個東西——副作用,是什么東西呢?副作用指的是:除了導出成員之外所做的事情,我舉個例子,下面的a.js是沒副作用的,b.js是有副作用的:

a.js

function console () {
  console.log('console')
}
export default {
  console
}

b.js

function console () {
  console.log('console')
}
// 這個就是副作用,會影響全局的數組
Array.prototype.func = () => {}
export default {
  console
}

有無副作用的判斷,可以決定tree-shaking的優化程度,舉個例子:

  • 我現在引入a.js但是我不用他的console函數,那么在優化階段我完全可以不打包a.js這個文件。

  • 我現在引入b.js但是我不用他的console函數,但是我不可以不打包b.js這個文件,因為他有副作用,不能不打包。

sideEffects的使用

sideEffects可以在package.json中設置:

// 所有文件都有副作用,全都不可 tree-shaking
{
 "sideEffects": true
}
// 沒有文件有副作用,全都可以 tree-shaking
{
 "sideEffects": false
}
// 只有這些文件有副作用,
// 所有其他文件都可以 tree-shaking,
// 但會保留這些文件
{
 "sideEffects": [
  "./src/file1.js",
  "./src/file2.js"
 ]
}

優化體積

當我把sideEffects設置成true之后,整個打包體積增加了100k,說明默認的false還是有用的。

以上就是關于“tree shaking對打包體積優化及作用實例分析”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女