V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
jin5354
V2EX  ›  分享创造

写了一个 axios 缓存插件,帮你缓存 GET 请求

  •  
  •   jin5354 ·
    jin5354 · 2017-06-25 10:15:27 +08:00 · 7571 次点击
    这是一个创建于 2755 天前的主题,其中的信息可能已经有所发展或是发生改变。

    业务上遇到了自己控制缓存的需求,于是在 axios 上实现了一个简单的缓存层,抽出来分享一下(`・ω・´)

    Github 仓库: axios-cache-plugin

    Build Status Coverage Status npm package npm downloads License: MIT

    安装

    npm install axios-cache-plugin --save-dev
    

    or

    yarn add axios-cache-plugin --dev
    

    使用

    引入 wrapper,然后裹在 axios 或者 axios 实例上并用返回值替代即可,不用修改业务代码

    import axios from 'axios'
    import wrapper from 'axios-cache-plugin'
    
    let http = wrapper(axios, {
      maxCacheSize: 15
    })
    export default http
    

    API

    插件并不是缓存全部 GET 请求,而是按正则匹配缓存指定的请求,这要求你添加 filter,url 命中 filter 的请求才会被缓存哦。(默认情况下不缓存任何请求。)

    • instance.__addFilter 添加 filter
    • instance.__removeFilter 移除 filter
    import axios from 'axios'
    import wrapper from 'axios-cache-plugin'
    
    let http = wrapper(axios, {
      maxCacheSize: 15
    })
    http.__addFilter(/users/)  //添加一个 filter
    
    http({
      url: 'http://www.404forest.com:3000/users/jin5354',
      //命中 filter 啦,现在 http://www.404forest.com:3000/users/jin5354?test=something 结果会被缓存
      method: 'get',
      params: {
        test: 'something'
      }
    })
    
    http({
      url: 'http://www.404forest.com:3000/users/jin5354',
       //重复请求直接返回缓存结果,不再发新请求了。
      method: 'get',
      params: {
        test: 'something'
      }
    })
    

    wrapper option

    包装 axios 实例时可以指定两个缓存配置项:maxCacheSize 和 ttl,非必需指定

    maxCacheSize 指定最多可缓存的条目数,超过这个数量时最早的缓存会被删除,默认为 15

    ttl 指缓存存活时间,单位为 ms,超过这个时间缓存条目自动消除。

    let http = wrapper(axios, {
      maxCacheSize: 15,
      ttl: 60000
    })
    

    积极维护中,欢迎反馈

    5 条回复    2017-07-13 17:05:06 +08:00
    v1024
        1
    v1024  
       2017-06-25 10:39:24 +08:00 via iPhone
    滋瓷,mark
    MinonHeart
        2
    MinonHeart  
       2017-06-25 11:46:45 +08:00 via iPhone
    需要把浏览器缓存踢掉
    jin5354
        3
    jin5354  
    OP
       2017-06-25 13:10:54 +08:00
    @MinonHeart
    请求会先通过 axios 的缓存层,再走浏览器缓存,如果两个缓存都存在,可以节省一次 304
    当然先把浏览器缓存禁掉控制更准确一些
    leopku
        4
    leopku  
       2017-06-25 14:48:03 +08:00
    滋瓷
    star
    skxtay
        5
    skxtay  
       2017-07-13 17:05:06 +08:00
    滋瓷
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1037 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 37ms · UTC 19:59 · PVG 03:59 · LAX 11:59 · JFK 14:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.