webpack性能优化(一) |
您所在的位置:网站首页 › webpack怎么做性能优化 › webpack性能优化(一) |
webpack性能优化(一). 性能优化 一、减少模块解析1.什么叫做模块解析2.不做模块解析会怎样3.哪些模块不需要解析4.如何让某个模块不要解析 二、优化loader性能1.进一步限制loader的应用范围2.缓存loader的结果3.为loader的运行开启多线程 三、热替换 HMR1.流程2.使用和原理3.样式热替换 一、减少模块解析 1.什么叫做模块解析模块解析包括:抽象语法树分析、依赖分析、模块语法替换
如果没有loader对该模块进行处理,该模块的源码就是最终打包结果的代码。 如果不对某个模块进行解析,可以缩短构建时间 3.哪些模块不需要解析模块中无其他依赖:一些已经打包好的第三方库,比如jquery 4.如何让某个模块不要解析配置module.noParse,它是一个正则,被正则匹配到的模块不会解析 module.exports = { mode: "development", devtool: "source-map", module: { noParse: /test/ //匹配test相关文件 } } 二、优化loader性能 1.进一步限制loader的应用范围思路是:对于某些库,不使用loader 例如:babel-loader可以转换ES6或更高版本的语法,可是有些库本身就是用ES5语法书写的,不需要转换,使用babel-loader反而会浪费构建时间 lodash就是这样的一个库 lodash是在ES5之前出现的库,使用的是ES3语法 通过module.rule.exclude或module.rule.include,排除或仅包含需要应用loader的场景 module.exports = { module: { rules: [ { test: /\.js$/, exclude: /lodash/, use: "babel-loader" } ] } }如果暴力一点,甚至可以排除掉node_modules目录中的模块,或仅转换src目录的模块 module.exports = { module: { rules: [ { test: /\.js$/, exclude: /node_modules/, //或 // include: /src/, use: "babel-loader" } ] } }这种做法是对loader的范围进行进一步的限制,和noParse不冲突,想想看,为什么不冲突 2.缓存loader的结果我们可以基于一种假设:如果某个文件内容不变,经过相同的loader解析后,解析后的结果也不变 于是,可以将loader的解析结果保存下来,让后续的解析直接使用保存的结果 cache-loader可以实现这样的功能 module.exports = { module: { rules: [ { test: /\.js$/, use: [ {loader:'cache-loader', cacheDirectory: './cache' //指定缓存的目录 }, ...loaders ] }, ], }, };有趣的是,cache-loader放到最前面,却能够决定后续的loader是否运行 实际上,loader的运行过程中,还包含一个过程,即pitch cache-loader还可以实现各自自定义的配置,具体方式见文档 3.为loader的运行开启多线程thread-loader会开启一个线程池,线程池中包含适量的线程 它会把后续的loader放到线程池的线程中运行,以提高构建效率 由于后续的loader会放到新的线程中,所以,后续的loader不能: 使用 webpack api 生成文件无法使用自定义的 plugin api无法访问 webpack options在实际的开发中,可以进行测试,来决定thread-loader放到什么位置 特别注意,开启和管理线程需要消耗时间,在小型项目中使用thread-loader反而会增加构建时间 三、热替换 HMR 1.流程热替换并不能降低构建时间(可能还会稍微增加),但可以降低代码改动到效果呈现的时间 当使用webpack-dev-server时,考虑代码改动到效果呈现的过程 首先,这段代码会参与最终运行! 当开启了热更新后,webpack-dev-server会向打包结果中注入module.hot属性 默认情况下,webpack-dev-server不管是否开启了热更新,当重新打包后,都会调用location.reload刷新页面 但如果运行了module.hot.accept(),将改变这一行为(不再调用location.reload) module.hot.accept()的作用是让webpack-dev-server通过socket管道,把服务器更新的内容发送到浏览器 插件HotModuleReplacementPlugin会根据覆盖原始代码,然后让代码重新执行**(不改变原始文件,是重新调用然后覆盖修改的已经变化的代码)** 所以,热替换发生在代码运行期 3.样式热替换对于样式也是可以使用热替换的,但需要使用style-loader 因为热替换发生时,HotModuleReplacementPlugin只会简单的重新运行模块代码 因此style-loader的代码一运行,就会重新设置style元素中的样式 而mini-css-extract-plugin,由于它生成文件是在构建期间,运行期间并会也无法改动文件,因此它对于热替换是无效的 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |