浏览器的缓存机制

前言

这也是一道很基础的面试常考题。当涉及到网络浏览器的速度和性能时,缓存机制是一个不可忽视的关键因素。无论是浏览网页、查看图片还是播放视频,缓存都发挥着至关重要的作用。缓存机制我们就从强缓存和协商缓存两个方面来说。

强缓存

  1. Cache-Control

    其实缓存机制简单来说就是对一部分的请求将其结果缓存在浏览器中,在有效时间内重复请求则无需再次访问服务器。直接从浏览器的缓存资源中获取即可。 第一个Cache-Control 就是通过在请求头中设置Cache-Control:max-age ,则在max-age 内重复请求则无需访问服务器。

js 复制代码
res.writeHead(status, {
'Content-Type': 'text/html;charset="utf-8"', 
'Cache-Control': 'max-age=86400'
})
  1. Expires Expires 和第一个Cache-Control类似,都是直接在响应头中设置过期时间即可。

协商缓存

其实浏览器本身并没有强缓存和协商缓存的区分,这些都是程序员为了工作中方便称呼而取的名字。协商缓存本质上其实就是改写了缓存过期的机制,让缓存的生命周期在一个合理的范围,不会太早过期也不会在浏览器中保存过于长久。增强用户的体验。

  1. If-None-Match:etag

If-None-Match:etage 在浏览器首次请求返回数据时会带上这个etag,浏览器端就将其保存。在下一次请求时就带上并和服务端保存的进行对比,如果一致直接返回304从本地缓存中提取结果。不一致则重新请求并带回新的etag。这个etag可以直接使用缓存的整个文件进行一个转码,这样在文件修改时就能够生成一个新的etag。

  1. If-Modified-Since

这个用法也和If-None-Match:etag 是差不多的,这个一般是通过文件的last-modified属性,和上一次保存的last-modified时间戳进行对比,如果上一次的时间早于这次返回的时间也进行一个更新。

尾声

本文主要目的是为了带大家了解浏览器缓存机制这个概念,可能讲的并没有很深入,但是可以让你在面试的时候回答面试官的问题了。但是还是建议大家可以深入了解一下,因为缓存机制在平时的工作中也是能够用到的。我们还是需要会使用的。

相关推荐
谎言西西里5 小时前
JS 高手必会:手写 new 与 instanceof
javascript
雪碧聊技术6 小时前
前端项目代码发生改变,如何重新部署到linux服务器?
前端·vue3·centos7·代码更新,重新部署
liulilittle7 小时前
C++ 浮点数封装。
linux·服务器·开发语言·前端·网络·数据库·c++
无责任此方_修行中7 小时前
亲历外企裁员:上午还在写代码,下午工位就空了
面试·程序员·求职
wordbaby7 小时前
Expo 进阶指南:赋予 TanStack Query “原生感知力” —— 深度解析 AppState 与 NetInfo
前端·react native
Moment7 小时前
从美团全栈化看 AI 冲击:前端转全栈,是自救还是必然 🤔🤔🤔
前端·后端·面试
天问一7 小时前
使用 Vue Router 进行路由定制和调用的示例
前端·javascript·vue.js
老王熬夜敲代码8 小时前
C++中的atomic
开发语言·c++·笔记·面试
a努力。8 小时前
腾讯Java面试被问:String、StringBuffer、StringBuilder区别
java·开发语言·后端·面试·职场和发展·架构
韩立学长8 小时前
【开题答辩实录分享】以《基于Vue的非遗文化知识分享平台的设计与实现》为例进行选题答辩实录分享
前端·javascript·vue.js