面试题(六)

110 阅读3分钟

「这是我参与2022首次更文挑战的第22天,活动详情查看:2022首次更文挑战」。

Javascript本地存储的方式有哪些?区别及应用场景?

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

  1. cookie
  2. sessionStorage
  3. localStorage
  4. indexedDB

1. cookie

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

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

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

  • Expires 用于设置 Cookie 的过期时间
  • Max-Age 用于设置在 Cookie 失效之前需要经过的秒数(优先级比 Expires 高)
  • Domain指定了 Cookie 可以送达的主机名
  • Path 定了一个URL路径,这个路径必须出现在要请求的资源的路径中才可以发送 Cookie 首部 Path docs # docs Web 下的资源会带 Cookie 首部 .

2. sessionStorage

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

localStorage看下面

3. localStorage

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

特点:

  • 生命周期:持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的 。
  • 存储的信息在同域中是共享的
  • 当本页操作(新增、修改、删除)了localStorage的时候,本页面不会触发storage事件,但是别的页面会触发storage 事件
  • 大小:5M(跟浏览器厂商有关系)
  • localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡
  • 受同源策略的限制

4. indexedDB

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

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

优点:

  • 储存量理论上没有上限
  • 所有操作都是异步的,相比LocalStorage 同步操作性能更高,尤其是数据量较大时
  • 原生支持储存JS的对象
  • 是个正经的数据库,意味着数据库能干的事它都能干

缺点:

  • 操作非常繁琐
  • 本身有一定门槛 关于indexedDB的使用基本使用步骤如下:
  • 打开数据库并且开始一个事务
  • 创建一个 object store
  • 构建一个请求来执行一些数据库操作,像增加或提取数据等
  • 通过监听正确类型的DOM事件以等待操作完成
  • 在操作结果上进行一些操作(可以在 request对象中找到) 关于使用indexdb的使用会比较繁琐,大家可以通过使用Godb.js库进行缓存,最大化的降低操作难度