Skip to content

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

Posted on:2024年7月22日 at 11:14

一、方式

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

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

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

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

关于cookie常用的属性如下:

Expires=Wed, 21 Oct 2015 07:28:00 GMT
Max-Age=604800
Path=/docs   # /docs/Web/ 下的资源会带 Cookie 首部

通过上述,我们可以看到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过期后会被浏览器删除

localStorage

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

特点

下面再看看关于localStorage的使用

设置

localStorage.setItem("username", "cfangxu");

获取

localStorage.getItem("username");

获取键名

localStorage.key(0); //获取第一个键名

删除

localStorage.removeItem("username");

一次性清除所有存储

localStorage.clear();

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

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

sessionStorage

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

扩展的前端存储方式

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

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

优点:

缺点:

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

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

二、区别

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

三、应用场景

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

原文转自:https://fe.ecool.fun/topic/74cf701d-95e7-428a-a7c1-d746c6c0877c