webpack:详解cache模块常用配置

背景

持久化缓存算得上是 Webpack 5 最令人振奋的特性之一,它能够将首次构建结果持久化到本地文件系统,在下次执行构建时跳过一系列解析、链接、编译等非常消耗性能的操作,直接复用 module、chunk 的构建结果。

cache 会在开发模式被设置成 type: 'memory' 而且在生产模式中被禁用。 cache: truecache: { type: 'memory' } 配置作用一致。 传入 false 会禁用缓存:

常用配置

cache.type

缓存类型,支持 'memory' | 'filesystem',需要设置 filesystem 才能开启持久缓存。

当将 cache.type 设置为 'filesystem' 是会开放更多的可配置项。

cache.cacheDirectory

缓存文件存放的路径,默认为 node_modules/.cache/webpack

cache.buildDependencies

额外的依赖文件,当这些文件内容发生变化时,缓存会完全失效而执行完整的编译构建,通常可设置为项目配置文件,如:

js 复制代码
module.exports = {
  cache: {
    buildDependencies: {
      config: [path.join(__dirname, 'webpack.dll_config.js')],
    },
  },
};

官方推荐的是:

js 复制代码
module.exports = {
  cache: {
    buildDependencies: {
      // This makes all dependencies of this file - build dependencies
      config: [__filename],
      // 默认情况下 webpack 与 loader 是构建依赖。
    },
  },
};

也就是说当前的 webpack 配置文件如果不改变的话,那就会一直使用缓存

相关推荐
草帽lufei4 分钟前
3大免费AI工具实战测评,用提示词“调教”出业务大屏
前端·ai编程·trae
汉堡大王95277 分钟前
JavaScript类型变形记:当代码开始“不正经”地转换身份
前端·javascript
Miss妤9 分钟前
Gemini写应用(二)
前端
用户930510658222410 分钟前
自造微前端
前端·javascript
之恒君10 分钟前
寄生组合继承 vs ES6 类继承 深度对比
前端·javascript
涔溪12 分钟前
整理vue3+ vite 开发经常会遇到的问题。
前端·vue.js·typescript
用户516816614584116 分钟前
script 标签的异步加载:async、defer、type="module" 详解
前端·javascript
m0_4711996322 分钟前
【vue】dep.notify() 是什么意思?
前端·javascript·vue.js
威风的虫26 分钟前
Vue3中的生命周期钩子函数
前端·javascript·vue.js
m0_471199631 小时前
【vue】vue2和vue3响应式原理区别
前端·javascript·vue.js