【Webpack】实现持久化缓存

embedded/2024/10/20 17:31:33/

回答重点

在 Webpack 中实现持久化缓存有几个关键策略,最核心的就是利用文件内容哈希,使得文件名发生变化,这样浏览器就会识别为新的资源而不是使用缓存的旧资源。具体步骤如下:

1)使用 output.filenameoutput.chunkFilename 配置项来添加哈希:

output: {filename: '[name].[contenthash].js',chunkFilename: '[name].[contenthash].js',
}

2)使用合适的插件来优化缓存,例如 HtmlWebpackPlugin 生成带有哈希的文件引用,以及 MiniCssExtractPlugin 用于 CSS 文件名哈希:

const HtmlWebpackPlugin = require('html-webpack-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');plugins: [new HtmlWebpackPlugin({template: './src/index.html',}),new MiniCssExtractPlugin({filename: '[name].[contenthash].css',}),
]

3)开启长效缓存管理:使用 webpack.NamedModulesPluginwebpack.HashedModuleIdsPlugin,确保模块id在内容不变的情况下保持一致:

optimization: {moduleIds: 'hashed',
}
plugins: [new webpack.HashedModuleIdsPlugin(),
]

4)分离供应商代码(第三方库)和应用代码,利用 SplitChunksPlugin

optimization: {splitChunks: {chunks: 'all',},
}

扩展知识

在实现持久化缓存方面,我们可以进一步优化和理解一些概念和工具:

1)Contenthash 与 Chunkhash:了解 contenthashchunkhash 的区别至关重要。contenthash 是基于文件内容生成的哈希,任何内容改变都会导致哈希变化。而 chunkhash 则是基于整个 chunk 的内容进行哈希计算。

2)缓存优化策略

  • 浏览器缓存:配置 HTTP 头,如 Cache-ControlETag,使得浏览器缓存策略与文件名哈希结合,进一步提升缓存效率。
  • Service Worker:利用 Service Worker 缓存策略,通过 Workbox 等工具实现更细粒度的缓存控制。

3)Tree Shaking 和 Dead Code Elimination

  • 使用 mode: 'production'TerserWebpackPlugin 来启用 Tree Shaking 和去除无用代码,减少最终产出文件体积。

4)Differential Loading:针对不同的浏览器特性生成不同的构建版本 (现代浏览器和旧版浏览器),利用 @babel/preset-envtargets 选项和 Webpack 的 environment 目标进行指导。

5)Monitor Cache Performance:使用工具如 Lighthouse 来分析和评估缓存性能,从具体的报告中找出改进点。


http://www.ppmy.cn/embedded/118266.html

相关文章

elasticsearch学习与实战应用

目录 前言一、学习路径二、核心概念三、实战应用四、优化策略总结前言 Elasticsearch的学习与实战应用是一个涉及多个方面的过程,以下将从学习路径、核心概念、实战应用及优化策略等方面进行详细介绍。 提示:以下是本篇文章正文内容,下面案例可供参考 一、学习路径 1. 基…

yolov5/8/9/10模型在VOC数据集上的应用【代码+数据集+python环境+GUI系统】

yolov5/8/9/10模型在VOC数据集上的应用【代码数据集python环境GUI系统】 1.背景意义 VOC数据集被广泛应用于计算机视觉领域的研究和实验中,特别是目标检测和图像识别任务。许多知名的目标检测算法都使用VOC数据集进行训练和测试。VOC挑战赛(VOC Challeng…

mac命令行分卷压缩与合并

对当前目录内的文件压缩的同时分卷 //语法:zip -r -s 1m 压缩文件名.zip 当前路径 zip -r -s 1m split.zip . //解压 zip -s 0 split.zip --out unsplit.zip unzip unsplit.zip 将一个zip文件进行分卷 一个900k的压缩包名为hello.zip,将其分割为每500K一个zip zip - hello.…

Java项目实战II基于Java+Spring Boot+MySQL的网上摄影工作室(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发,CSDN平台Java领域新星创作者 一、前言 在数字化时代,摄影艺术已不再局限于传统媒介,而是借助互联网平台绽放新的光彩…

IEEE Transactions on Consumer Electronics (TCE)投稿指南

期刊官网:IEEE Transactions on Consumer Electronics 期刊模板下载:IEEE Transactions Template 投稿地址:IEEE Transactions on Consumer Electronic Submit System 期刊投稿guideline: IEEE Transactions on Consumer Electronics Submis…

Java | Leetcode Java题解之第429题N叉树的层序遍历

题目&#xff1a; 题解&#xff1a; class Solution {public List<List<Integer>> levelOrder(Node root) {if (root null) {return new ArrayList<List<Integer>>();}List<List<Integer>> ans new ArrayList<List<Integer>&g…

docker 部署minio

docker部署minio 前提部署minio连接minio参考链接 前提 已安装docker 部署minio mkdir -p ~/minio/datadocker run \-p 9000:9000 \-p 9001:9001 \--name minio \-v ~/minio/data:/data \-e "MINIO_ROOT_USERROOTNAME" \-e "MINIO_ROOT_PASSWORDCHANGEME123&…

视频怎么提取音频?一键音频提取,视频内容轻松听!

视频怎么提取音频&#xff1f;一键解锁音频世界&#xff0c;让视频精彩不再静默&#xff01;无论您是忙碌于日常工作的上班族&#xff0c;还是热衷于学习的求知者&#xff0c;亦或是享受闲暇时光的聆听者&#xff0c;一键提取音频功能让视频内容瞬间转化为耳畔的温柔低语&#…