分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 网页技术

Webpack 的 Tree Shaking

发布时间:2023-09-06 02:25责任编辑:白小东关键词:Web
  • 为什么要使用 Tree Shaking?
    当从某文件模块中导出(某一个或几个变量、函数、对象等),然而这个文件模块还有许多其它(我们这次并不需要)的导出,webpack会不管三七二十一简单粗暴的将整个模块包含进来,使得我们最终打包的文件里有了许多不需要的垃圾。这就到了tree shaking出手的地方了,因为它能帮助我们干掉那些用不到的代码,大大减少打包的尺寸。

  • 要想让tree shaking能“摇起来”,有几个要求:
    第一个要求,必须使用ES6模块,不能使用其它类型的模块如CommonJS之流。如果使用Babel的话,这里有一个小问题,因为Babel的预案(preset)默认会将任何模块类型都转译成CommonJS类型。修正这个问题也很简单,在.babelrc文件或在webpack.config.js文件中设置modules: false就好了。
// .babelrc{ ?"presets": [ ???["env", ?????{ ???????"modules": false ?????} ???] ?]}
// webpack.config.jsmodule: { ???rules: [ ???????{ ???????????test: /\.js$/, ???????????exclude: /(node_modules)/, ???????????use: { ???????????????loader: ‘babel-loader‘, ???????????????options: { ???????????????????presets: [‘env‘, { modules: false }] ???????????????} ???????????} ???????} ???]}

第二个要求,需要使用UglifyJsPlugin插件。如果在mode:"production"模式,这个插件已经默认添加了,如果在其它模式下,可以手工添加它。
第三个要求,打开optimization.usedExports。在mode: "production"模式下,它也是默认打开了的。它告诉webpack每个模块明确使用exports。这样之后,webpack会在打包文件中添加诸如/* unused harmony export */这样的注释,其后UglifyJsPlugin插件会对这些注释作出理解。

Webpack 的 Tree Shaking

原文地址:https://www.cnblogs.com/cag2050/p/10086940.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved