| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 网络协议 -> Webpack5之babel缓存以及文件资源缓存 -> 正文阅读 |
|
[网络协议]Webpack5之babel缓存以及文件资源缓存 |
要说文件资源缓存那就得先了解一下浏览器的缓存机制 浏览器大概可以分为强制缓存(强缓存)和协商缓存 浏览器每次与服务器通信的方式为应答模式,即:浏览器发起HTTP请求 – 服务器响应该请求。那么浏览器第一次向服务器发起该请求后拿到请求结果,会根据响应报文中HTTP头的缓存标识,决定是否缓存结果,是则将请求结果和缓存标识存入浏览器缓存中,简单的过程图如下: 由上图我们可以知道:
这里我们来着重说一下强制缓存 强制缓存 强制缓存就是向浏览器缓存查找该请求结果,并根据该结果的缓存规则来决定是否使用该缓存结果的过程,强制缓存的情况主要有三种(暂不分析协商缓存过程),如下: 不存在该缓存结果和缓存标识,强制缓存失效,则直接向服务器发起请求(跟第一次发起请求一致),如下图: 存在该缓存结果和缓存标识,但该结果已失效,强制缓存失效,则使用协商缓存(暂不分析),如下图 ? 存在该缓存结果和缓存标识,且该结果尚未失效,强制缓存生效,直接返回该结果,如下图?
当浏览器向服务器发起请求时,服务器会将缓存规则放入HTTP响应报文的HTTP头中和请求结果一起返回给浏览器,控制强制缓存的字段分别是Expires和Cache-Control,其中Cache-Control优先级比Expires高。 在我们的HTTP/1.1中Expire已经被Cache-Control替代,所以这里我就只说明Cache-Control。 Cache-Control 在HTTP/1.1中,Cache-Control是最重要的规则,主要用于控制网页缓存,主要取值为:
接下来我们看一个例子: 如上图,这里的?Cache-Control设立了public和max-age说明该请求的所有内容在规定的时间内会被强制缓存,即就是如果该请求文件名称不发生变化的化会一直读取缓存文件。 第一次请求: ?当刷新页面再次请求: 接下来说说文件资源缓存在打包过程中的处理方式为了让代码上线运行缓存更好使用,我们在webpack打包过程中,如果修改了相应的css或者js文件的话,因为浏览器的强缓存机制,在打包后我们的页面是不会发生变动的,所以在我们的webpack中需要对打包后的文件名进行相应的处理,去告诉浏览器这是个新的文件(发生变动的文件)需要重新请求资源。 在webpack中输出文件通常有三种命名方式: ?hash:每次webpack打包会生成一个唯一的hash值 ? ? ? ?问题:因为js和css同时使用一个hash值 如果重新打包会导致所有缓存失效(可能我只改动一个文件) chunkhash:根据chunk生成hash值。如果打包来源同一个chunk,那么hash值一样 ? ? ? ?问题:js和css的hash值还是一样,因为css是在js中被引入的,所以同属于一个chunk contenthash:根据文件的内容生成hash值。不同文件的hash值一定不一样 上述方法可以看出使用contenthash的方式输出文件是最好的方法。 接下来说说babel的缓存原理我们在webpack中使用babel-loader是去为了兼容我们的js代码,将更高级的语法转译成浏览器所能识别语法。 为了确保这个过程更加快速准确,我们可以看一下官方文档是怎么做的 下面是我的做法 这里开启了cacheDirectory缓存,可以让我们的转译结果进行一个本地缓存,在我们之后的打包过程中如果js没有进行修改的话可以直接从缓存中读取文件进行输出,我来解释一下cacheDirectory缓存的原理 cacheDirectory原理当有设置 |
|
网络协议 最新文章 |
使用Easyswoole 搭建简单的Websoket服务 |
常见的数据通信方式有哪些? |
Openssl 1024bit RSA算法---公私钥获取和处 |
HTTPS协议的密钥交换流程 |
《小白WEB安全入门》03. 漏洞篇 |
HttpRunner4.x 安装与使用 |
2021-07-04 |
手写RPC学习笔记 |
K8S高可用版本部署 |
mySQL计算IP地址范围 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/6 20:19:24- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |