前端关于cookies , sessionStorage 和localStorage 的区别及使用

本文深入解析了前端存储技术,包括cookie、sessionStorage和localStorage的区别。详细介绍了它们的存储大小、有效时间及用法,提供了代码示例,帮助读者理解如何在实际项目中应用这些存储方式。
摘要由CSDN通过智能技术生成

cookie是网站为了标示用户身份而储存在用户本地终端(Client Side)上的数据 - 通常经过加密
cookie数据始终在同源的http请求中携带,即使不需要,也会在浏览器和服务器间来回传递。
sessionStorage和localStorage不会自动把数据发给服务器,仅在本地保存

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

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

用法

 localstorage 和 sessionstorage

首先要判断浏览器是否支持 localStorage / sessionStorage
比如判断 localStorage

if (window.localStorage) {
    alert('浏览支持 localStorage');
} else {
    alert('浏览暂不支持 localStorage');
}

localStorage 和 sessionStorage 都具有相同的操作方法,例如 setItem()getItem()removeItem()

储存数据
用途: 将 value 存储到 key 字段
用法: setItem( key, value)
代码示例

sessionStorage.setItem('key', 'value');
localStorage.setItem('key', 'value');

注: 如果需要储存数组或对象的话, 可以用JSON格式传入

取出数据
用途: 获取指定 key 本地存储的值
用法: getItem(key)
代码示例

sessionStorage.getItem('key');
localStorage.getItem('key');

修改数据
用途: 修改指定 key 本地存储的值
用法: setItem(key)
代码示例

sessionStorage.setItem('key', 'newVal');
localStorage.setItem('key', 'newVal');

删除数据
用途: 删除指定 key 本地存储的值
用法: removeItem(key)
代码示例

sessionStorage.removeItem('key');
localStorage.removeItem('key');

清除数据
用途: 清除所有本地存储的数据
用法: clear()
代码示例

sessionStorage.clear();
localStorage.clear();

cookie

储存数据

window.document.cookie = 'key=val';

取出数据

document.cookie

example:

// 设置 Cookie
setCookie(key, val, days) {
    let date = new Date(); // 获取时间
    date.setTime(date.getTime() + 24 * 60 * 60 * 1000 * days);
    // 字符串拼接 Cookie
    window.document.cookie = `${key}=${val};path=/;expires=${date.toGMTString()};`;
}

 

// 获取 Cookie
getCookie() {
    let cookie = document.cookie.split(';');
}

 

// 清除Cookie
clearCookie() {
    this.setCookie('', '', -1);
}


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值