美文网首页程序员
HTML 本地存储

HTML 本地存储

作者: InFatuated | 来源:发表于2020-08-06 13:48 被阅读0次

HTML本地存储:优于cookies

什么是HTML本地存储?

通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储。
在HTML5之前,应用程序数据只能存储在cookie中,包括每个服务器请求。本地存储则更加安全,并且可在不影响网站性能的前提将大量数据存储于本地。
与cookie不同,存储限制要大得多(至少5MB),并且信息不会被传输到服务器。
本地存储经由起源地(orgin)(经由域和协议)。所有页面,从起源地,能够存储和访问相同的数据。

浏览器支持

表格中的数组指示了完全支持本地存储的首个浏览器版本。


HTML本地存储对象
HMTL本地存储提供了两个在客户端存储数据的对象:

  • window.localStorage - 存储没有截止日期的数据
  • window.sessionStorage - 针对一个seession来存储数据(当关闭浏览器标签时数据会丢失)

在使用本地存储时,请检测localStorage和sessionStorage的浏览器支持:

if (typeof(Storage) !== "undefined") {
    // 针对 localStorage/sessionStorage 的代码
} else {
    // 抱歉!不支持 Web Storage ..
}

localStorage对象

localStorage 对象存储的是没有截止日期的数据。当浏览器被关闭时数据不会被删除,在下一天、周或年中,都是可用的。
实例

// 存储
localStorage.setItem("lastname", "Gates");
// 取回
document.getElementById("result").innerHTML = localStorage.getItem("lastname");

实例解释:

  • 创建localStorage名称/值对,其中:name="lastname",value="Gates"
  • 取回"lastname"的值,并把它插到id="result"的元素中
    上例也可这样写:
// 存储
localStorage.lastname = "Gates";
// 取回
document.getElementById("result").innerHTML = localStorage.lastname;

删除"lastname"localStorage项目的语法如下:

localStorage.removeItem("lastname");

注释:名称/值对始终存储为字符串。如果需要请记得把它们转换为其他格式!
下面的例子对用户点击按钮的次数进行计数。在代码中,值字符串被转换为数值,依次对计数进行递增:
实例

if (localStorage.clickcount) {
    localStorage.clickcount = Number(localStorage.clickcount) + 1;
} else {
    localStorage.clickcount = 1;
}
document.getElementById("result").innerHTML = "您已经点击这个按钮 " +
localStorage.clickcount + " 次。";

sessionStorage对象

sessionStorage对象等同于localStorage对象,不同之处在于只对一个session存储数据。如果用户关闭具体的浏览器标签页,数据也会被删除。
下例在当前session中对用户点击按钮进行计数:
实例

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

相关文章

网友评论

    本文标题:HTML 本地存储

    本文链接:https://www.haomeiwen.com/subject/lhorrktx.html