您的位置:首页 > Web前端 > Webpack

Webpack 打包优化之体积篇

2017-11-06 09:11 197 查看
谈及如今欣欣向荣的前端圈,不仅有各类框架百花齐放,如
Vue
, 
React
, 
Angular
等等,就打包工具而言,发展也是如火如荼,百家争鸣;从早期的王者
Browserify
Grunt
,到后来赢得宝座的 
Gulp
, 以及独树一帜的 
fis3
,
以及下一代打包神器 
Rollup
 ;在 browserify,grunt,gulp,rollup,webpack 可以一窥其中部分对比。在本文要探究的是,当前打包工具绝对霸者 
Webpack




Webpack
Package optimization

Webpack
,当前各大主流框架默认配备的打包方案,对其如何使用,已有较完备中英文文档;并且,各主流框架也有对应 
CLI
 予以基础配置,故不作为探讨范畴。从产品层来讲,如何使得构建的包体积小、运行快,这有必要不断摸索实践,提炼升级,使之臻于最佳。本文将从以下些许方面,对 
Webpack
 打包体积方面,做下优化探讨(备注: 
Webpack
实践版本: 
3.3.0
):

定位 webpack 大的原因

这里推荐使用 webpack-bundle-analyzer —— Webpack 插件和 CLI 实用程序,她可以将内容束展示为方便交互的直观树状图,让你明白你所构建包中真正引入的内容;我们可以借助她,发现它大体有哪些模块组成,找到不合时宜的存在,然后优化它。我们可以在
项目的 package.json 文件中注入如下命令,以方便运行她(
npm run analyz
),默认会打开 http://127.0.0.1:8888 作为展示。

“analyz”: “NODE_ENV=production npm_config_report=true npm run build”



webpack-bundle-analyzer

当然,同类型的还有 webpack-chart 以及 webpack-analyse,这两个站点也是以可视方式呈现构造的组件,可以让你清楚的看到模块的组成部分;不过稍显麻烦的是,你需要运行以下命令,生成工具分析所需要的
json 文件:

1234
webpack --profile --json > stats.json// 如果,运行指定的 weboack 文件,可用此命令webpack --config build/webpack.prod.conf.js  --profile --json > stats.json

引入
DllPlugin 和 DllReferencePlugin

DllPlugin 和 DllReferencePlugin 提供了以大幅度提高构建时间性能的方式拆分软件包的方法。其中原理是,将特定的第三方NPM包模块提前构建
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: