CacheStorage详解

简介: CacheStorage 是 Web API 的一部分,用于管理缓存对象的存储。它允许开发者在客户端存储和检索请求-响应对,实现离线访问和性能优化。通过 CacheStorage 接口,可以创建、删除和查询缓存,以及控制资源的缓存策略。
  1. CacheStorage的基本概念

    • 定义与作用:CacheStorage是浏览器提供的一种存储机制,用于缓存网络资源,如脚本、样式表、图片等。它是Service Worker API的一部分,目的是为了提高网页的性能和离线可用性。例如,当用户第一次访问一个网页时,浏览器可以将网页的一些关键资源(如HTML文件、主要的CSS和JavaScript文件)存储到CacheStorage中。当下次访问该网页或者在离线状态下再次请求这些资源时,浏览器可以直接从CacheStorage中获取,而不必重新从网络下载,从而加快了网页的加载速度。
    • 与其他存储机制的关系:与localStorage和sessionStorage不同,CacheStorage主要用于缓存网络请求的响应,并且存储的内容通常是由浏览器或Service Worker自动管理的。而localStorage和sessionStorage主要用于存储应用程序的数据,如用户的偏好设置、登录状态等,并且是通过JavaScript代码显式地进行存储和读取操作。
  2. CacheStorage的使用方法

    • 打开和获取缓存(Cache)对象
      • 可以通过caches.open()方法来打开一个指定名称的缓存。如果缓存不存在,则会创建一个新的缓存。例如:
        caches.open('my - cache - name').then((cache) => {
                 
          // 在这里可以使用cache对象进行操作
        });
        
      • 打开缓存后,可以使用cache对象进行各种操作,如添加、匹配和删除缓存项。
    • 添加缓存项
      • 可以使用cache.addAll()方法来添加一组资源到缓存中。这些资源通常是通过网络请求获取的响应。例如,在Service Worker中,可以这样添加缓存项:
        self.addEventListener('fetch', function (event) {
                 
          event.respondWith(
              caches.open('my - cache - name').then((cache) => {
                 
                  return cache.addAll([
                      '/',
                      '/index.html',
                      '/styles.css',
                      '/script.js'
                  ]);
              })
          );
        });
        
      • 上述代码在fetch事件中,当Service Worker拦截到网络请求时,会尝试将指定的资源添加到名为my - cache - name的缓存中。
    • 匹配缓存项
      • 使用cache.match()方法可以在缓存中查找与给定请求匹配的缓存项。例如,在Service Worker的fetch事件处理程序中,可以这样使用:
        self.addEventListener('fetch', function (event) {
                 
          event.respondWith(
              caches.open('my - cache - name').then((cache) => {
                 
                  return cache.match(event.request).then((response) => {
                 
                      if (response) {
                 
                          return response;
                      }
                      return fetch(event.request);
                  });
              })
          );
        });
        
      • 这段代码首先尝试从缓存中查找与请求匹配的响应,如果找到则直接返回缓存中的响应,否则通过fetch方法从网络获取响应。
    • 删除缓存项和缓存本身
      • 可以使用cache.delete()方法删除缓存中的单个项目。例如,要删除一个特定的URL对应的缓存项,可以这样做:
        caches.open('my - cache - name').then((cache) => {
                 
          cache.delete('/old - resource.html');
        });
        
      • 要删除整个缓存,可以使用caches.delete()方法并指定缓存的名称。例如:
        caches.delete('my - cache - name');
        
  3. CacheStorage的生命周期和缓存策略

    • 缓存的生命周期
      • 缓存项在CacheStorage中的存储时间是由缓存策略决定的。一些缓存可能会一直存储,直到用户手动清除浏览器缓存或者缓存被代码显式删除。而另一些缓存可能会根据一定的规则(如缓存过期时间、资源更新情况等)自动更新或清除。
      • 例如,在设置缓存时,可以通过在响应头中添加Cache - ControlExpires等字段来指定缓存的有效期。浏览器会根据这些信息来判断何时需要重新获取资源,而不是使用缓存中的旧资源。
    • 缓存策略
      • 强缓存策略:如果响应头中有Cache - Control: max - age = 31536000(表示缓存有效期为一年)这样的设置,并且缓存尚未过期,浏览器会直接使用缓存中的资源,而不会发送网络请求。这种策略适用于那些很少变化的资源,如网站的图标、一些基础的JavaScript库等。
      • 协商缓存策略:当响应头中有Last - ModifiedETag等字段时,浏览器在使用缓存资源之前会先发送一个条件请求(例如,在请求头中带上If - Modified - SinceIf - None - Match字段)到服务器,询问资源是否已经更新。如果服务器返回304 Not Modified响应,表示资源没有更新,浏览器继续使用缓存中的资源;如果服务器返回新的资源内容,浏览器更新缓存并使用新资源。这种策略适用于那些可能会定期更新的资源,如网页的HTML文件等。
相关文章
|
资源调度 前端开发 jenkins
前端工程化(Frontend Tooling):优化开发流程的关键
前端工程化是现代Web开发的关键组成部分,它包括一系列工具、实践和流程,旨在提高开发效率、代码质量和可维护性。本博客将深入探讨前端工程化的概念、工具以及如何在项目中应用它们,以改善您的前端开发体验。
1106 0
|
NoSQL MongoDB Python
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
【Python】已完美解决(MongoDB安装报错)Service ‘MongoDB Server (MongoDB)’ (MongoDB) failed tostart
1143 1
|
API 容器
Flutter UI组件库(JUI)
Flutter UI组件库(JUI)
2822 17
|
安全 JavaScript Shell
vite中环境变量的使用与配置,非常实用详细!
【8月更文挑战第2天】vite中如何使用环境变量?根据当前的代码环境产生值的变化的变量就叫做环境变量。本文将详细介绍vite中如何使用环境变量
1865 1
|
JSON API 数据处理
如何运用获得京东商品详情API接口搬运商品到自己的电商平台?(一篇文章全搞定)
本文介绍如何利用京东商品详情API接口,将商品信息高效搬运至第三方电商平台。主要内容包括:前期准备(注册账号、申请权限、阅读文档、技术准备),API接口调用(构造请求URL、发送请求、解析返回数据、调用频率限制),数据处理与上架(清洗整理、分类设置、信息上传、商品审核),定时更新与维护(更新商品信息、信息维护、错误处理与日志记录),以及案例分析和优化建议。通过合理使用该接口,可提高运营效率,丰富商品种类,增强平台竞争力。
394 13
ELK 圣经:Elasticsearch、Logstash、Kibana 从入门到精通
ELK是一套强大的日志管理和分析工具,广泛应用于日志监控、故障排查、业务分析等场景。本文档将详细介绍ELK的各个组件及其配置方法,帮助读者从零开始掌握ELK的使用。
|
机器学习/深度学习 算法 TensorFlow
深度学习笔记(五):学习率过大过小对于网络训练有何影响以及如何解决
学习率是深度学习中的关键超参数,它影响模型的训练进度和收敛性,过大或过小的学习率都会对网络训练产生负面影响,需要通过适当的设置和调整策略来优化。
2514 0
深度学习笔记(五):学习率过大过小对于网络训练有何影响以及如何解决
|
存储 缓存 JSON
详解HTTP四种请求:POST、GET、DELETE、PUT
【4月更文挑战第3天】
72896 5
详解HTTP四种请求:POST、GET、DELETE、PUT
|
存储 JavaScript 前端开发
【面试官系列】React 中,如何在页面刷新之后保持状态?看看你知道几种~
【面试官系列】React 中,如何在页面刷新之后保持状态?看看你知道几种~
【面试官系列】React 中,如何在页面刷新之后保持状态?看看你知道几种~
|
存储 监控 NoSQL
Redis中的LRU淘汰策略深入解析
Redis的内存管理关键在于处理数据增长与有限内存的矛盾,LRU策略被广泛用于此。LRU基于“不常访问的数据未来访问可能性小”的假设,淘汰最近最少使用的数据。Redis通过双向链表实现,但并非严格LRU,而是采样算法以平衡性能和精度。用户可通过调整`maxmemory-samples`等参数优化。尽管LRU简单高效,但无法区分数据重要性和访问频率,可能误淘汰重要数据。合理设置参数、结合其他策略、监控调优是优化LRU使用的关键。
508 1

热门文章

最新文章