html 本地存储传递参数,HTML5本地存储 localStorage 和 sessionStorage

什么是 HTML 本地存储?

本地存储是指将web应用的数据保存到浏览器端,而不是保存到服务端。通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储,提高网站的效率,减少HTTP请求,节省带宽。

在 HTML5 之前,应用程序数据只能存储在 cookie 中,包括每个服务器请求。本地存储则更安全,并且可在不影响网站性能的前提下将大量数据存储于本地。与 cookie 不同,本地存储限制要大得多(至少5MB),并且信息不会被传输到服务器。

HTML 本地存储对象

HTML 本地存储提供了两个在客户端存储数据的对象:window.localStorage - 存储没有截止日期的数据,即使你关闭了浏览器,数据依然存在

window.sessionStorage - 针对一个 session 来存储数据(当关闭浏览器标签页时数据会丢失)

在使用本地存储时,请检测 localStorage 和 sessionStorage 的浏览器支持:if (typeof(Storage) !== "undefined") {

// 针对 localStorage/sessionStorage 的代码

} else {

// 抱歉!不支持 Web Storage ..

}

localStorage 对象

localStorage 对象存储的是没有截止日期的数据。当浏览器被关闭时数据不会被删除,在下一天、周或年中,都是可用的。localStorage 对象有下面三个重要的方法:localStorage.setItem(key, value) 将指定key的value数据保存到本地存储

localStorage.getItem(key) 从本地存储获取指定key的值

localStorage.removeItem(key) 从本地存储移除指定的key

实例:

if (typeof(Storage) !== "undefined") {

// 针对 localStorage/sessionStorage 的代码

var key = "localKey"

// 设置值到本地缓存

localStorage.setItem(key, new Date().toLocaleDateString());

// 从本地缓存获取值

console.log( localStorage.getItem(key) );

setTimeout(function(){

// 从缓存中删除

localStorage.removeItem(key);

console.log(localStorage.getItem(key));

}, 10000);

} else {

// 抱歉!不支持 Web Storage ...

console.log("抱歉!不支持 Web Storage...");

}

注释:名称/值对始终存储为字符串。如果需要请记得把它们转换为其他格式!

sessionStorage 对象

sessionStorage 对象等同 localStorage 对象,不同之处在于只对一个 session 存储数据。如果用户关闭具体的浏览器标签页,数据也会被删除。sessionStorage 对象有下面三个重要的方法:sessionStorage .setItem(key, value) 将指定key的value数据保存到本地存储

sessionStorage .getItem(key) 从本地存储获取指定key的值

sessionStorage .removeItem(key) 从本地存储移除指定的key

下例在当前 session 中对用户点击按钮进行计数:

if (typeof(Storage) !== "undefined") {

// 针对 localStorage/sessionStorage 的代码

var key = "sessionKey"

// 设置值到本地缓存

sessionStorage.setItem(key, new Date().toLocaleDateString());

// 从本地缓存获取值

console.log( sessionStorage.getItem(key) );

setTimeout(function(){

// 从缓存中删除 key

sessionStorage.removeItem(key);

console.log(sessionStorage.getItem(key));

}, 10000);

} else {

// 抱歉!不支持 Web Storage ...

console.log("抱歉!不支持 Web Storage...");

}

实例:下例在当前 session 中对用户点击按钮进行计数:if (sessionStorage.clickcount) {

sessionStorage.clickcount = Number(sessionStorage.clickcount) + 1;

} else {

sessionStorage.clickcount = 1;

}

document.getElementById("result").innerHTML = "在本 session 中,您已经点击这个按钮 " + sessionStorage.clickcount + " 次。";

当然也可以是这样:if (sessionStorage.getItem("clickcount") {

sessionStorage.setItem("clickcount", Number(sessionStorage.clickcount) + 1);

} else {

sessionStorage.setItem("clickcount", 1);

}

document.getElementById("result").innerHTML = "在本 session 中,您已经点击这个按钮 " + sessionStorage.getItem("clickcount ") + " 次。";

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值