前端缓存策略及其应用场景详解

 更新时间:2025年07月16日 09:34:23   作者:执梦起航  
缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物这篇文章主要介绍了前端缓存策略及其应用场景的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下

前端缓存是提升网站性能和用户体验的关键技术,主要分为 浏览器缓存应用层缓存CDN缓存、内存缓存。以下是常见策略及其应用场景:

一、浏览器缓存(HTTP 缓存)

1. 强缓存(Cache-Control/Expires)

  • 原理:直接使用本地缓存,无需请求服务器。
  • 控制头
    • Cache-Control: max-age=3600(优先)
    • Expires: Wed, 21 Oct 2025 07:28:00 GMT(旧版,受本地时间影响)
  • 适用场景:静态资源(如 JS、CSS、图片)。
  • 示例配置(Nginx)
    location ~* \.(js|css|png|jpg|gif|svg)$ {
        expires 7d;  # 缓存 7 天
        add_header Cache-Control "public";
    }
    

2. 协商缓存(ETag/Last-Modified)

  • 原理:发送请求到服务器验证缓存是否可用,若未修改则返回 304。
  • 控制头
    • ETag: "123456789"(文件哈希值)
    • Last-Modified: Wed, 21 Oct 2025 07:28:00 GMT(文件修改时间)
  • 适用场景:可能变化但需精确控制的资源(如用户头像)。
  • 示例代码(Node.js)
    const http = require('http');
    const fs = require('fs');
    const crypto = require('crypto');
    
    http.createServer((req, res) => {
      fs.readFile('index.html', (err, data) => {
        const hash = crypto.createHash('md5').update(data).digest('hex');
        if (req.headers['if-none-match'] === hash) {
          res.statusCode = 304;
          return res.end();
        }
        res.setHeader('ETag', hash);
        res.end(data);
      });
    }).listen(3000);
    

二、应用层缓存

1. LocalStorage/SessionStorage

  • 特点
    • 存储大小:5-10MB(不同浏览器)。
    • 数据类型:字符串(需 JSON 序列化)。
    • 有效期:localStorage 永久,sessionStorage 会话结束清除。
  • 适用场景:用户偏好设置、临时数据(如购物车)。
  • 示例代码
    // 存储
    localStorage.setItem('user', JSON.stringify({ name: 'John', age: 30 }));
    
    // 读取
    const user = JSON.parse(localStorage.getItem('user'));
    

2. IndexedDB

  • 特点
    • 存储大小:无明确限制(受硬盘空间约束)。
    • 支持事务和索引,适合存储结构化数据。
    • 异步 API,避免阻塞主线程。
  • 适用场景:大量数据缓存(如离线地图、邮件客户端)。
  • 示例代码
    const request = indexedDB.open('myDatabase', 1);
    
    request.onsuccess = (event) => {
      const db = event.target.result;
      const transaction = db.transaction(['users'], 'readwrite');
      const store = transaction.objectStore('users');
      store.put({ id: 1, name: 'John' });
    };
    

3. Service Worker

  • 特点
    • 运行在浏览器后台的独立线程。
    • 拦截网络请求,实现离线缓存和推送通知。
  • 适用场景:离线应用(如 PWA)、静态资源预缓存。
  • 示例代码(注册 Service Worker)
    if ('serviceWorker' in navigator) {
      navigator.serviceWorker.register('/service-worker.js')
        .then(registration => {
          console.log('Service Worker 注册成功');
        });
    }
    
     
    // service-worker.js
    self.addEventListener('fetch', (event) => {
      event.respondWith(
        caches.match(event.request)
          .then(cachedResponse => cachedResponse || fetch(event.request))
      );
    });
    

三、CDN 缓存

  • 原理:内容分发网络在全球多个节点缓存资源,用户就近访问。
  • 优势
    • 加速静态资源加载(如 JS 库、图片)。
    • 减轻源服务器压力。
  • 示例配置(使用 UNPKG CDN)
    <script src="https://unpkg.com/react@18.2.0/umd/react.production.min.js"></script>
    

四、内存缓存(Runtime Cache)

  • 特点
    • 存储在 JS 变量中,读取速度极快。
    • 页面刷新后失效。
  • 适用场景:高频访问数据(如用户信息)。
  • 示例代码
    const cache = new Map();
    
    function getData(key) {
      if (cache.has(key)) {
        return cache.get(key);
      }
      const data = fetchDataFromServer(key);
      cache.set(key, data);
      return data;
    }
    

五、缓存策略选择指南

场景推荐缓存方案
静态资源(JS/CSS/ 图片)HTTP 强缓存 + CDN
动态数据(如 API 响应)协商缓存 + LocalStorage
离线应用Service Worker + IndexedDB
高频数据访问内存缓存(如 Map 对象)、vuex、pina
用户会话信息SessionStorage

总结

到此这篇关于前端缓存策略及其应用场景详解的文章就介绍到这了,更多相关前端缓存策略内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 9个JavaScript评级/投票插件

    9个JavaScript评级/投票插件

    在访问某个网站或者博客时,如果该站点为用户提供内容的评级或投票功能的话,可以增强用户参与的交互性之外,更可以给用户一种“主人”的亲切感,使得用户可以切实地参与到网站内容的评价体系中来。
    2010-01-01
  • JavaScript队列结构Queue实现过程解析

    JavaScript队列结构Queue实现过程解析

    这篇文章主要介绍了JavaScript队列结构Queue实现过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • JavaScript单线程和任务队列原理解析

    JavaScript单线程和任务队列原理解析

    这篇文章主要介绍了JavaScript单线程和任务队列原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-02-02
  • 浅谈Javascript事件对象

    浅谈Javascript事件对象

    本文主要介绍了Javascript事件对象的相关实例。具有一定的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • js实现根据身份证号自动生成出生日期

    js实现根据身份证号自动生成出生日期

    这篇文章主要介绍了js实现根据身份证号自动生成出生日期,需要的朋友可以参考下
    2015-12-12
  • IScroll5实现下拉刷新上拉加载的功能实例

    IScroll5实现下拉刷新上拉加载的功能实例

    本篇文章主要介绍了IScroll5实现下拉刷新上拉加载的功能实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • 深入理解JavaScript创建对象的多种方式以及优缺点

    深入理解JavaScript创建对象的多种方式以及优缺点

    本篇文章主要介绍了JavaScript创建对象的多种方式以及优缺点,主要介绍了5种方式,有兴趣的可以了解下
    2017-06-06
  • ES2015 Symbol 一种绝不重复的值

    ES2015 Symbol 一种绝不重复的值

    这篇文章主要介绍了Symbol是ES2015新增的一种值类型数据,表示一种绝不重复的值,需要的朋友可以参考下
    2016-12-12
  • 基于javascript html5实现3D翻书特效

    基于javascript html5实现3D翻书特效

    这篇文章主要介绍了基于javascript html5实现翻书特效的实现方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-03-03
  • js隐藏与显示回到顶部按钮及window.onscroll事件应用

    js隐藏与显示回到顶部按钮及window.onscroll事件应用

    现在大多数网站都会添加这种功能:当滚动条滚动到页面的下方时,页面的右下角会显示出来一个“回到顶部”的按钮或连接;那么,如何控制“回到顶部”按钮的显示或隐藏呢;本文介绍详细实现方法,感兴趣的你可不要走开哦
    2013-01-01

最新评论