0

0

JS缓存机制的五个关键要点总结

PHPz

PHPz

发布时间:2024-01-23 08:12:21

|

1497人浏览过

|

来源于php中文网

原创

知识大盘点:js缓存机制中的五个关键要点

知识大盘点:JS缓存机制中的五个关键要点,需要具体代码示例

导语:在前端开发中,缓存是提高网页性能的重要一环。JavaScript缓存机制是指将已经获取的资源保存在本地,以便在后续的访问中能够直接使用缓存,从而减少资源加载时间和网络带宽的消耗。本文将介绍JS缓存机制中的关键要点,并提供具体的代码示例。

一、缓存类型

  1. 强缓存

强缓存是指通过设置HTTP响应头中的Expires或Cache-Control字段来实现的缓存机制。当浏览器请求一个资源时,会先检查该资源在本地是否存在缓存,如果存在且仍在有效期内,则直接使用缓存,不再发送请求。

示例代码:

// 设置缓存时间为1个小时
res.setHeader('Cache-Control', 'max-age=3600');
  1. 协商缓存

协商缓存是通过设置HTTP请求头中的If-Modified-Since或If-None-Match字段来与服务器进行通信的缓存机制。当浏览器请求一个资源时,会先发送请求到服务器,服务器根据请求头中的字段和资源的最后修改时间进行比较,如果资源未发生变化,则返回状态码304 Not Modified,并通知浏览器使用本地缓存。

示例代码:

// 获取请求头中的If-Modified-Since字段
const ifModifiedSince = req.headers['if-modified-since'];

// 获取资源的最后修改时间
const lastModified = fs.statSync(filepath).mtime.toUTCString();

// 比较请求头中的字段与最后修改时间
if (ifModifiedSince === lastModified) {
  res.statusCode = 304; // Not Modified
  res.end();
} else {
  res.setHeader('Last-Modified', lastModified);
  // 返回资源
  res.end(file);
}

二、缓存位置

  1. 浏览器缓存

浏览器缓存是指缓存在浏览器本地的缓存文件。当浏览器访问同一资源时,会先检查该资源是否存在缓存文件,如果存在则直接使用缓存,否则发送网络请求。

示例代码:

// 读取缓存
const cache = localStorage.getItem('cache');

// 判断缓存是否存在
if (cache) {
  // 使用缓存
} else {
  // 发送网络请求
}
  1. 服务器缓存

服务器缓存是指缓存在服务器端的缓存文件。当浏览器请求一个资源时,服务器会检查该资源是否存在缓存文件,如果存在则直接返回缓存文件。

示例代码:

// 判断文件是否存在
if (fs.existsSync(filepath)) {
  // 返回缓存文件
} else {
  // 发送网络请求
}

三、缓存时间控制

  1. 缓存时间

缓存时间是指强缓存或协商缓存的有效期时间,可以根据需求设置不同的缓存时间。

RecoveryFox AI
RecoveryFox AI

AI驱动的数据恢复、文件恢复工具

下载

示例代码:

// 设置缓存时间为1个小时
res.setHeader('Cache-Control', 'max-age=3600');
  1. 缓存策略

缓存策略是指根据资源类型或资源路径设置不同的缓存策略。可以使用正则表达式或字符串匹配来实现不同的缓存策略。

示例代码:

// 设置图片资源的缓存时间为1个月
if (req.url.match(/.jpg|.png|.gif$/)) {
  res.setHeader('Cache-Control', 'max-age=2592000');
}

四、缓存更新

  1. 版本控制

版本控制是指在请求资源时添加版本号,当资源发生改变时更新版本号。通过更新版本号可以强制浏览器重新加载资源。

示例代码:



  1. 强制刷新

强制刷新是指通过设置Cache-Control字段的max-age为0来告诉浏览器立即更新缓存。

示例代码:

// 强制刷新缓存
res.setHeader('Cache-Control', 'max-age=0');

五、缓存清除

缓存清除是指手动删除浏览器本地的缓存文件或服务器端的缓存文件。

示例代码:

// 清除浏览器缓存
localStorage.removeItem('cache');

// 清除服务器缓存
fs.unlinkSync(filepath);

总结:对于前端开发中常见的JS缓存机制,我们介绍了五个关键要点,涉及的内容包括缓存类型、缓存位置、缓存时间控制、缓存更新和缓存清除。掌握这些关键要点能够帮助我们更好地理解和应用缓存机制,提升网页性能,提升用户体验。希望通过本文的介绍,能够对各位读者有所帮助。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

251

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

746

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

215

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

236

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

532

2023.12.06

clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

19

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.6万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号