写点什么

关于 JavaScript 的本地存储方案

作者:CoderBin
  • 2022-10-25
    广东
  • 本文字数:2279 字

    阅读完需:约 7 分钟

关于JavaScript的本地存储方案

前言

大家好,我是 CoderBin,本次总结了 JavaScript 中本地存储的四种方案,希望对大家有所帮助,谢谢!如果文中有不对、疑惑的地方,欢迎在评论区留言指正🌻


高频面试总结

【1】关于Vue的一些高频面试题总结

【2】75道关于CSS的高频面试题总结,请注意查收!🔥

面试官系列文章

【1】面试官系列-专栏

一、本地存储方案

javaScript 本地缓存的方案我们主要讲述以下四种:


  1. localStorage

  2. sessionStorage

  3. cookie

  4. indexedDB

1. localStorage

HTML5新方法,IE8 及以上浏览器都兼容


特点


  • 生命周期:持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的

  • 存储的信息在同一域中是共享的

  • 当本页操作(新增、修改、删除)了localStorage的时候,本页面不会触发storage事件,但是别的页面会触发storage事件。

  • 大小:5M(跟浏览器厂商有关系)

  • localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡

  • 受同源策略的限制


下面再看看关于localStorage的使用


设置


localStorage.setItem('username','CoderBin');
复制代码


获取


localStorage.getItem('username')
复制代码


获取键名


localStorage.key(0) //获取第一个键名
复制代码


删除


localStorage.removeItem('username')
复制代码


一次性清除所有存储


localStorage.clear()
复制代码


localStorage 也不是完美的,它有两个缺点:


  • 无法像Cookie一样设置过期时间

  • 只能存入字符串,无法直接存对象


localStorage.setItem('key', {name: 'value'});console.log(localStorage.getItem('key')); // '[object, Object]'
复制代码

2. sessionStorage

sessionStorage 和 localStorage 使用方法基本一致,唯一不同的是生命周期,一旦页面(会话)关闭,sessionStorage 将会删除数据

3. cookie

Cookie,类型为「小型文本文件」,指某些网站为了辨别用户身份而储存在用户本地终端上的数据。是为了解决 HTTP 无状态导致的问题


作为一段一般不超过 4KB 的小型文本数据,它由一个名称(Name)、一个值(Value)和其它几个用于控制 cookie 有效期、安全性、使用范围的可选属性组成


但是cookie在每次请求中都会被发送,如果不使用 HTTPS 并对其加密,其保存的信息很容易被窃取,导致安全风险。举个例子,在一些使用 cookie 保持登录态的网站上,如果 cookie 被窃取,他人很容易利用你的 cookie 来假扮成你登录网站


关于cookie常用的属性如下:


  • Expires 用于设置 Cookie 的过期时间


Expires=Wed, 21 Oct 2015 07:28:00 GMT
复制代码


  • Max-Age 用于设置在 Cookie 失效之前需要经过的秒数(优先级比Expires高)


Max-Age=604800
复制代码


  • Domain 指定了 Cookie 可以送达的主机名

  • Path 指定了一个 URL 路径,这个路径必须出现在要请求的资源的路径中才可以发送 Cookie 首部


Path=/docs # /docs/Web/ 下的资源会带 Cookie 首部
复制代码


  • 标记为 Secure 的 Cookie 只应通过被HTTPS协议加密过的请求发送给服务端


通过上述,我们可以看到cookie又开始的作用并不是为了缓存而设计出来,只是借用了cookie的特性实现缓存


关于cookie的使用如下:


document.cookie = '名字=值';
复制代码


关于cookie的修改,首先要确定domainpath属性都是相同的才可以,其中有一个不同得时候都会创建出一个新的cookie


Set-Cookie:name=aa; domain=aa.net; path=/  # 服务端设置document.cookie =name=bb; domain=aa.net; path=/  # 客户端设置
复制代码


最后cookie的删除,最常用的方法就是给cookie设置一个过期的事件,这样cookie过期后会被浏览器删除

4. indexedDB

indexedDB 是一种低级 API,用于客户端存储大量结构化数据(包括, 文件/ blobs)。该 API 使用索引来实现对该数据的高性能搜索


虽然 Web Storage 对于存储较少量的数据很有用,但对于存储更大量的结构化数据来说,这种方法不太有用。IndexedDB提供了一个解决方案


优点:


  • 储存量理论上没有上限

  • 所有操作都是异步的,相比 LocalStorage 同步操作性能更高,尤其是数据量较大时

  • 原生支持储存JS的对象

  • 是个正经的数据库,意味着数据库能干的事它都能干


缺点:


  • 操作非常繁琐

  • 本身有一定门槛


关于indexedDB的使用基本使用步骤如下:


  • 打开数据库并且开始一个事务

  • 创建一个 object store

  • 构建一个请求来执行一些数据库操作,像增加或提取数据等。

  • 通过监听正确类型的 DOM 事件以等待操作完成。

  • 在操作结果上进行一些操作(可以在 request 对象中找到)


关于使用indexdb的使用会比较繁琐,大家可以通过使用Godb.js库进行缓存,最大化的降低操作难度

二、区别

关于cookiesessionStoragelocalStorage三者的区别主要如下:


  • 存储大小:cookie数据大小不能超过4ksessionStoragelocalStorage虽然也有存储大小的限制,但比cookie大得多,可以达到 5M 或更大

  • 有效时间:localStorage存储持久数据,浏览器关闭后数据不丢失除非主动删除数据; sessionStorage数据在当前浏览器窗口关闭后自动删除;cookie设置的cookie过期时间之前一直有效,即使窗口或浏览器关闭

  • 数据与服务器之间的交互方式,cookie的数据会自动的传递到服务器,服务器端也可以写cookie到客户端; sessionStoragelocalStorage不会自动把数据发给服务器,仅在本地保存

三、应用场景

在了解了上述的前端的缓存方式后,我们可以看看针对不对场景的使用选择:


  • 标记用户与跟踪用户行为的情况,推荐使用cookie

  • 适合长期保存在本地的数据(令牌),推荐使用localStorage

  • 敏感账号一次性登录,推荐使用sessionStorage

  • 存储大量数据的情况、在线文档(富文本编辑器)保存编辑历史的情况,推荐使用indexedDB




每文一句:立身以立学为先,立学以读书为本。


本次的分享就到这里,如果本章内容对你有所帮助的话欢迎点赞+收藏。文章有不对的地方欢迎指出,有任何疑问都可以在评论区留言。希望大家都能够有所收获,大家一起探讨、进步!

发布于: 2022-10-25阅读数: 15
用户头像

CoderBin

关注

不念过往,不惧将来 2020-10-14 加入

普通人只考虑他们将如何度过时间,而有智慧的人则试图利用时间 — CoderBin

评论

发布
暂无评论
关于JavaScript的本地存储方案_JavaScript_CoderBin_InfoQ写作社区