js【详解】本地存储 Cookie、sessionStorage、localStorage

简介: js【详解】本地存储 Cookie、sessionStorage、localStorage

【考题】Cookie、sessionStorage、localStorage的区别

特性 Cookie sessionStorage localStorage
数据有效期 可自定义失效时间,默认是关闭浏览器后失效 仅在当前会话下有效,关闭页面或浏览器后被清除 永久保存,除非代码/手动删除

存储数据 4KB 内 5MB 内
与服务器端通信 每次都会携带在HTTP头中,增加了请求数据量,如果cookie保存过多数据会影响性能 仅在客户端(即浏览器)中保存,不参与和服务器的通信
易用性 原生Cookie接口(document.cookie)不方便使用,通常使用插件js-cookie来操作Cookie 原生接口基本满足需求,也可再次封装来对Object和Array有更好的支持
使用场景

HTTP 请求需携带的信息,如鉴权token(判断用户是否登录)等

但在移动端表现不理想

任意需保存在客户端(即浏览器)的数据,如购物车信息、HTML5游戏的本地数据等

Cookie的用法

大多数浏览器只允许每个站点存储 50 个 Cookie;注意这里的50个是指主键值,也就是50条Cookies记录,但是每个Cookies记录还可以包含若干子键。

如果试图存储更多 Cookie,则最旧的 Cookie 便会被丢弃。有些浏览器还会对它们将接受的来自所有站点的 Cookie 总数作出绝对限制,通常为 300 个。

安装依赖

npm install js-cookie --save

导入依赖

import Cookies from 'js-cookie'

使用方法

// 新增/修改值(默认对整个站点有效)
Cookies.set("name", "朝阳");
// 指定Cookies有效期——适用于整个站点,7天内有效
Cookies.set('name', '朝阳', {expires: 7});
// 指定Cookies有效性——只适用于 /index 路由的页面,7天内有效,
Cookies.set('name', '朝阳', {expires: 7, path: '/index'});
 
// 获取值
let name = Cookies.get("name");
// 获取所有Cookies
let allCookies = Cookies.get();
 
// 删除值
Cookies.remove("name");
// 删除指定页面的 Cookies值
Cookies.remove('name', {path: '/index'});
 
//清除所有cookie(无需js-cookie依赖)
function clearAllCookie() {
    var keys = document.cookie.match(/[^ =;]+(?=\=)/g);
    if(keys) {
        for(var i = keys.length; i--;)
            document.cookie = keys[i] + '=0;expires=' + new Date(0).toUTCString()
    }
}

Cookie操作引用类型的数据(数组、对象等)

let user1 = {
    name: '朝阳',
    age: 18
}
 
// 存入Cookie
Cookies.set('user1', JSON.stringify(user1))
 
// 从Cookie中取出
let user1Temp = JSON.parse(Cookies.get('user1'))

sessionStorage的用法

// 新增/修改值
sessionStorage.setItem("name","朝阳");
// 获取值
let name=sessionStorage.getItem("name");
// 删除值
sessionStorage.removeItem("name");
// 清空值
sessionStorage.clear();

若操作引用类型的数据(数组、对象等),存入时,使用 JSON.stringify(data)将数据转化为字符串;取出时,使用JSON.parse()将数据还原

localStorage的用法

  • 如果存储内容过多,会消耗内存空间,导致页面卡顿
  • 浏览器的隐私模式下不可读取
  • localStorage 也存在同源策略,不同域名下的localStorage数据并不互通。
// 新增/修改值
window.localStorage.setItem("name","朝阳");
// 获取值
let name=window.localStorage.getItem("name");
// 删除值
window.localStorage.removeItem("name");
// 清空值
window.localStorage.clear();
 
// 引用类型的数据(数组、对象等),需先转换为字符串后,再存入
let list = [1,2,3]
window.localStorage.setItem("list",JSON.stringify(list));
 
// 读取非字符串类型的数据,记得先解析
let list2= JSON.parse(window.localStorage.getItem("list"));

浏览器中查看Cookie、sessionStorage、localStorage

F12开启浏览器调试窗口

Chrome谷歌浏览器

Firefox 火狐浏览器

360极速浏览器


目录
相关文章
|
3月前
|
存储 JavaScript 前端开发
vuex和localstorage . cookie的区别
【10月更文挑战第8天】
83 1
|
5月前
|
存储 JavaScript 前端开发
学习vuex和localstorage . cookie的作用与区别
探讨Vuex、LocalStorage与Cookie:三种关键技术在现代Web开发中的角色。Vuex作为Vue的状态管理工具,提供集中、响应式且可预测的状态变更机制,适用于复杂应用。LocalStorage为客户端提供大容量、持久化的数据存储方案,适合保存用户偏好等静态信息。Cookie则擅长会话跟踪与认证管理,数据虽小却能在客户端与服务器间传递。每种技术针对不同场景各有优势,合理选用是关键。
|
3月前
|
存储 JSON JavaScript
Vue.js开发中基于localStorage与sessionStorage的本地存储利器:Vue-ls插件使用详解
Vue.js开发中基于localStorage与sessionStorage的本地存储利器:Vue-ls插件使用详解
147 0
|
3月前
|
存储 缓存 JavaScript
cookie和localStorage的区别特点
cookie和localStorage的区别特点
231 0
|
4月前
|
存储 编解码 JSON
解决浏览器存储问题,不得不了解的cookie、localStorage和sessionStorage
该文章详细对比了浏览器存储机制中的cookie、localStorage和sessionStorage的不同之处,以及各自的适用场景。
|
5月前
|
存储 前端开发 JavaScript
揭秘!JavaScript本地存储的四大绝技:从Cookie到IndexedDB,让你的Web应用秒变数据存储高手,轻松应对各种挑战!
【8月更文挑战第4天】JavaScript为核心前端技术,提供多样本地存储方案以优化用户体验与减少服务器负载。首先,Cookie虽用于基本数据如登录状态,但受大小限制及安全性影响。接着,Web Storage中的LocalStorage持久存储不变数据,SessionStorage则限于单次会话。更进一步,IndexedDB作为全面数据库解决方案,支持复杂数据操作但使用较复杂。每种方式根据应用需求各有优势。
90 9
|
5月前
|
存储 缓存 JavaScript
cookie和localStorage的区别特点
cookie和localStorage的区别特点
75 0
|
25天前
|
存储 前端开发 Java
【SpringMVC】——Cookie和Session机制
获取URL中参数@PathVarible,上传文件@RequestPart,HttpServerlet(getCookies()方法,getAttribute方法,setAttribute方法,)HttpSession(getAttribute方法),@SessionAttribute
|
2月前
|
存储 安全 搜索推荐
理解Session和Cookie:Java Web开发中的用户状态管理
理解Session和Cookie:Java Web开发中的用户状态管理
94 4
|
2月前
|
存储 缓存 网络协议
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点,GET、POST的区别,Cookie与Session
计算机网络常见面试题(二):浏览器中输入URL返回页面过程、HTTP协议特点、状态码、报文格式,GET、POST的区别,DNS的解析过程、数字证书、Cookie与Session,对称加密和非对称加密