sessionStorage 的使用示例

sessionStorage 的使用与 localStorage 非常相似,但它有一个关键的区别:sessionStorage 存储的数据在页面会话期间有效,即数据在页面打开期间存在,当页面关闭(无论是通过关闭浏览器标签页、窗口还是整个浏览器)后,数据就会被删除。以下是一个使用 sessionStorage 的基本示例:

存储数据

使用 setItem(key, value) 方法来存储数据。同样地,value 必须是一个字符串,如果需要存储非字符串数据,需要先使用 JSON.stringify() 方法进行转换。

// 存储一个字符串  
sessionStorage.setItem('sessionId', '12345');  
  
// 存储一个对象(需要先转换为字符串)  
var userSession = { id: '67890', name: 'Alice' };  
sessionStorage.setItem('user', JSON.stringify(userSession));

获取数据

使用 getItem(key) 方法来获取之前存储的数据。如果找到了对应的 key,则返回其 value(作为字符串)。如果之前存储的是对象或数组,并使用 JSON.stringify() 进行了转换,那么在获取时需要使用 JSON.parse() 方法将其转换回原始数据类型。

// 获取并显示字符串  
var sessionId = sessionStorage.getItem('sessionId');  
console.log(sessionId); // 输出: 12345  
  
// 获取并解析对象  
var storedUser = sessionStorage.getItem('user');  
var userSession = JSON.parse(storedUser);  
console.log(userSession.name); // 输出: Alice

删除数据

使用 removeItem(key) 方法来删除存储在 sessionStorage 中的特定数据项。

// 删除用户会话信息  
sessionStorage.removeItem('user');  
  
// 尝试获取已删除的用户会话信息,将返回 null  
var deletedUser = sessionStorage.getItem('user');  
console.log(deletedUser); // 输出: null

页面会话的结束

请注意,sessionStorage 中的数据在页面会话结束时(即用户关闭浏览器标签页或窗口时)会被删除。如果用户在同一个标签页中打开了新的页面或重新加载了当前页面,sessionStorage 中的数据仍然可用,因为页面会话被认为是持续的。但是,如果用户在新的标签页或窗口中打开相同的网站,他们将无法访问之前标签页或窗口中 sessionStorage 存储的数据,因为每个标签页或窗口都有自己独立的 sessionStorage

清除所有数据

虽然 sessionStorage 会在页面会话结束时自动清除所有数据,但如果需要在页面会话期间清除所有数据,可以使用 clear() 方法。然而,在大多数情况下,这通常不是必要的,因为页面会话结束时数据自然会被清除。

// 清除 sessionStorage 中的所有数据(通常不需要,因为会话结束时会自动清除)  
sessionStorage.clear();

请记住,由于 sessionStorage 的数据存储在用户的浏览器中,并且与特定的页面会话相关联,因此它通常用于存储那些只需要在当前会话中保持的数据。

  • 9
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的LocalStorage和SessionStorage都是用来在浏览器中储数据的API,但是它们之间有一些区别。 LocalStorage是一种持久化储数据的方式,数据储在用户的本地浏览器中,并且在浏览器关闭后仍然可以访问。LocalStorage是基于域名的,即同一域名下的网页可以共享LocalStorage中储的数据。 SessionStorage也是一种浏览器中储数据的API,但是它的生命周期是在用户关闭当前浏览器窗口或者标签页之后就会自动销毁。SessionStorage也是基于域名的,即同一域名下的网页可以共享SessionStorage储的数据。 下面是一些LocalStorage和SessionStorage使用示例: 1. 储数据到LocalStorage中: ```javascript localStorage.setItem('key', 'value'); ``` 2. 从LocalStorage中获取数据: ```javascript var value = localStorage.getItem('key'); ``` 3. 删除LocalStorage中的数据: ```javascript localStorage.removeItem('key'); ``` 4. 将所有的LocalStorage数据清除: ```javascript localStorage.clear(); ``` 5. 储数据到SessionStorage中: ```javascript sessionStorage.setItem('key', 'value'); ``` 6. 从SessionStorage中获取数据: ```javascript var value = sessionStorage.getItem('key'); ``` 7. 删除SessionStorage中的数据: ```javascript sessionStorage.removeItem('key'); ``` 8. 将所有的SessionStorage数据清除: ```javascript sessionStorage.clear(); ``` 需要注意的是,LocalStorage和SessionStorage都只能储字符串类型的数据。如果要储其他类型的数据,需要进行类型转换。同时,由于LocalStorage和SessionStorage储空间有限,如果储的数据过多,可能会导致储失败。因此,在使用LocalStorage和SessionStorage时需要注意储的数据大小。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值