webpack优化分享

更新日期: 2019-09-15阅读: 2.3k标签: 优化

webpack整个的构建过程是基于事件流

Webpack 就像一条生产线,要经过一系列处理流程后才能将源文件转换成输出结果。 这条生产线上的每个处理流程的职责都是单一的,多个流程之间有存在依赖关系,只有完成当前处理后才能交给下一个流程去处理。 插件就像是一个插入到生产线中的一个功能,在特定的时机对生产线上的资源做处理。 Webpack 通过 Tapable 来组织这条复杂的生产线。 Webpack 在运行过程中会广播事件,插件只需要监听它所关心的事件,就能加入到这条生产线中,去改变生产线的运作。 Webpack 的事件流机制保证了插件的有序性,使得整个系统扩展性很好。


构建过程

  1. 优化webpack,初始化构造配置参数,构建compiler对象,挂载Tapable事件流钩子函数(plugin的apply方法)
  2. 入口,读取entries入口配置信息
  3. 阶段,依次读取入口文件,loader内容转换,AST语法树转换,依赖收集,逐个拉取依赖并重复上述过程,最终得到转换后的内容以及依赖关系
  4. 资源,根据入口与模块之间的依赖关系,组装chunk代码块,生成文件输出列表
  5. 成功,根据配置输出文件路径和文件名,将文件写入文件系统,完成构建


优化

resolve优化

减少 resolve 的解析

  1. resolve.extensions:用来表明文件后缀列表,默认查找顺序是 ['.js', '.json'],如果你的导入文件没有添加后缀就会按照这个顺序查找文件。我们应该尽可能减少后缀列表长度,然后将出现频率高的后缀排在前面
  2. resolve.alias:可以通过别名的方式来映射一个路径,能让 Webpack 更快找到路径
  3. resolve.mainFields:[‘main’],设置尽量少的值可以减少入口文件的搜索步骤
  4. module.noParse,排除不需要扫描的文件


loader优化

  1. Loader 的文件搜索范围
  2. cache-loader(将loader编译后的结果写入硬盘缓存)
  3. HappyPack可以将 Loader 的同步执行转换为并行的(目前基本弃用了)
  4. 排除node_modules等不需要编译的文件( exclude: /node_modules/ )
  5. 配置loader缓存参数,例如label( loader: 'babel-loader?cacheDirectory=true' )


plugin优化

  1. 使用 DLLPlugin打包公共代码
  2. ParallelUglifyPlugin开启多进程压缩JS文件
  3. IgnorePlugin(内置插件) 忽略某些模块
  4. LimitChunkCountPlugin合并细小的chunk代码块,减少http请求;MinChunkSizePlugin合并细小代码块


optimization

  1. splitChunks分块,缓存复用率在minChunks上的代码块
  2. minimizer中ParallelUglifyPlugin插件并行压缩代码
  3. concatenateModules串联到单个模块中的模块图段,production模式下默认开启
  • ...production模式下默认开启的优化选项


链接: https://fly63.com/article/detial/5934

js中for循环优化总结_如何提高程序的执行效率

在程序开发中,经常会使用到for循环的,但是很多人写的for循环效率都是比较低的,下面就举例说明,并总结优化for循环的方法,来提高我们程序的执行效率。

网站打开速度优化_如何提高网页访问速度技巧方法总结

网站的加载速度不仅影响着用户体验,也会影响搜索引擎的排名,在百度推出“闪电算法”以来,将网站首屏打开速度被列入优化排名行列,作为前端开发的我们需要如果来优化网站的打开速度呢?下面就整理挖掘出很多细节上可以提升性能的东西分享给大家

JS性能优化之文档片段createDocumentFragment

DocumentFragments是DOM节点。它们不是主DOM树的一部分。通常的用例是创建文档片段,将元素附加到文档片段,然后将文档片段附加到DOM树。在DOM树中,文档片段被其所有的子元素所代替。因为文档片段存在于内存中,并不在DOM树中

深入浅出代码优化﹣if/else

对于代码裡面的 if else,我们可以使用逻辑判断式,或更好的三元判断式来优化代码。除了可以降低维护项目的成本之外,还可以提升代码可读性。就让我们从最简单的 if else 例子开始吧。

微信小程序性能优化入门指南

小程序从发布到现在也已经有将近两年的时间,越来越来多的公司开始重视小程序生态带来的流量,今年也由于小程序平台对外能力的越来越多的开放以及小程序平台的自身优化,越来越多的开发者也自主的投入到小程序的开发当中

网络串流播放_HTML5如何优化视频文件以便在网络上更快地串流播放

无论你正在将 GIF 动图转换为 MP4 视频,还是手头已经有一大堆 MP4 视频,你都可以优化文件结构,以使得这些视频更快地加载和播放。通过重组 atoms 将 moov 放到文件开头,浏览器可以避免发送额外的 HTTP range request 请求来搜寻和定位 moovatom

​web项目优化_Web 服务器性能与站点访问性能优化

要优化 Web 服务器的性能,我们先来看看 Web 服务器在 web 页面处理上的步骤:Web 浏览器向一个特定的服务器发出 Web 页面请求; Web 服务器接收到 web 页面请求后,寻找所请求的 web 页面,并将所请求的 Web 页面传送给 Web 浏览器; 显示出来

前端性能优化之重排和重绘

浏览器下载完页面所有的资源后,就要开始构建DOM树,于此同时还会构建渲染树(Render Tree)。(其实在构建渲染树之前,和DOM树同期会构建Style Tree。DOM树与Style Tree合并为渲染树)

微信小程序代码优化总汇

写篇文章的目的,是以开放小程序代码的层面的优化。包括:条件判断将wx:if换成了hidden 、页面跳转请销毁之前使用的资源、列表的局部更新、小程序中多张图片懒加载方案、Input状态下隐藏input,应预留出键盘收起的时间

我是如何将页面加载时间从6S降到2S的?

生活在信息爆炸的今天,我们每天不得不面对和过滤海量的信息--无疑是焦躁和浮动的,这就意味着用户对你站点投入的时间可能是及其吝啬的(当然有一些刚需站点除外)。如何给用户提供迅速的响应就显得十分重要了

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!