浏览器缓存

106 阅读4分钟

一、http缓存

http缓存是存在于服务器与浏览器之间,是一种保存资源副本并在下次请求时直接使用该副本的技术。web缓存发现请求资源已经被存储,它会拦截请求,返回资源副本,而不会去服务器重新请求资源。

二、WebSQL

websql这种方式只有较新的chrome浏览器支持,并以一个独立规范形式出现,主要有以下特点:

  • Web Sql 数据库API 实际上不是html5规范的组成部分;
  • 在html5之前就已经存在了,是单独的规范;
  • 它是将数据以数据库的形式存储在客户端,根据需求去读取;
  • 跟Storage的区别是: Storage和Cookie都是以键值对的形式存在的;
  • Web Sql 更方便于检索,允许sql语句查询;
  • 让浏览器实现小型数据库存储功能;
  • 这个数据库是集成在浏览器里面的,目前主流浏览器基本都已支持;

websql API主要包含三个核心方法:

  1. openDatabase : 这个方法使用现有数据库或创建新数据库创建数据库对象。
  2. transaction : 这个方法允许我们根据情况控制事务提交或回滚。
  3. executeSql : 这个方法用于执行真实的SQL查询。

三、indexDB

IndexedDB 是一个为了能够在客户端存储可观数量的结构化数据,并且在这些数据上使用索引进行高性能检索的 API。虽然 DOM 存储,对于存储少量数据是非常有用的,但是它对大量结构化数据的存储就显得力不从心了。IndexedDB 则提供了这样的一个解决方案。

IndexedDB 的特点有:

  • indexDB大小取决于你的硬盘,存储的数据量非常大。
  • 可以直接存储任何类型的数据,如 js任何类型的数据 、blob流。
  • 可以创建索引,提供高性能搜索功能。
  • 采用事务,保证数据的准确性和一致性。

四、cookie

cookie指的就是会话跟踪技术。一般指网站为了辨别用户身份,进行session跟踪而而存储在用户本地终端上的数据,cookie一般通过http请求头发送到服务器。cookie主要特点有:

  • 跨域限制,同一个域名下可多个网页内使用。
  • cookie可以设置有效期,超出有效期自动清除。
  • cookie存储大小在4K以内。
  • cookie的存储不能超过50个cookie。
  • 只能存储字符串类型。

五、localstorage

localStorage是HTML5的一种新的本地缓存方案,目前用的比较多,一般用来存储ajax返回的数据,加快下次页面打开时的渲染速度。

localStorage核心API:

localStorage.setItem(key, value)   //设置记录

localStorage.getItem(key)          //获取记录

localStorage.removeItem(key)        //删除该域名下单条记录

localStorage.clear()               //删除该域名下所有记录
复制代码

值得注意的是,localstorage大小有限制,不适合存放过多的数据,如果数据存放超过最大限制会报错,并移除最先保存的数据。

六、sessionstorage

sessionStorage与上述localStroage类似,它的特点主要有:

  • 存储的数据在浏览器关闭后删除,与网页窗口具有相同的生命周期。
  • 可以存储的数据大小5M。
  • 存储的数据不会发送到服务器。

七、application cache

application cahce是将大部分图片资源、js、css等静态资源放在manifest文件配置中。当页面打开时通过manifest文件来读取本地文件或是请求服务器文件。

离线访问对基于网络的应用而言越来越重要。虽然所有浏览器都有缓存机制,但它们并不可靠,也不一定总能起到预期的作用。HTML5 使用ApplicationCache 接口可以解决由离线带来的部分难题。前提是你需要访问的web页面至少被在线访问过一次。

使用缓存接口可为您的应用带来以下三个优势:

  • 离线浏览 – 用户可在离线时浏览您的完整网站。
  • 速度 – 缓存资源为本地资源,因此加载速度较快。
  • 服务器负载更少 – 浏览器只会从发生了更改的服务器下载资源。

八、cacheStorage

CacheStorage是在ServiceWorker的规范中定义的。CacheStorage 可以保存每个serverWorker申明的cache对象,cacheStorage有open、match、has、delete、keys五个核心方法,可以对cache对象的不同匹配进行不同的响应。

cacheStorage.has():如果包含cache对象,则返回一个promise对象。

cacheStorage.open():打开一个cache对象,则返回一个promise对象。

cacheStorage.delete():删除cache对象,成功则返回一个promise对象,否则返回false。

cacheStorage.keys():含有keys中字符串的任意一个,则返回一个promise对象。

cacheStorage.delete():匹配key中含有该字符串的cache对象,返回一个promise对象。

九、flash缓存

这种方式基本不用,这一方法主要基于flash有读写浏览器端本地目录的功能,同时也可以向js提供调用的api,则页面可以通过js调用flash去读写特定的磁盘目录,达到本地数据缓存的目的。