HTML Web 本地存储 API 您所在的位置:网站首页 论文修改意见反馈怎么写 HTML Web 本地存储 API

HTML Web 本地存储 API

2024-04-16 09:10| 来源: 网络整理| 查看: 265

❮ 上一节 下一节 ❯ HTML 本地存储

HTML 本地存储:优于 cookies。

什么是 HTML 本地存储?

通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储。

在 HTML5 之前,应用程序数据只能存储在 cookie 中,包括每个服务器请求。本地存储则更安全,并且可在不影响网站性能的前提下将大量数据存储于本地。

与 cookie 不同,存储限制要大得多(至少5MB),并且信息不会被传输到服务器。

本地存储经由起源地(origin)(经由域和协议)。所有页面,从起源地,能够存储和访问相同的数据。

浏览器支持

表中的数字指定了完全支持网络存储的第一个浏览器版本。

API Web Storage 4.0 8.0 3.5 4.0 11.5 HTML 本地存储对象

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

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

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

if (typeof(Storage) !== "undefined") {   // localStorage/sessionStorage 的代码。 } else {   // Sorry! 没有网络存储支持.. } localStorage 对象

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

实例 // StorelocalStorage.setItem("lastname", "Smith");

// Retrieve document.getElementById("result").innerHTML = localStorage.getItem("lastname");

亲自试一试 »

示例说明:

创建 localStorage 名称/值对,其中:name="lastname",value="Gates" 取回 "lastname" 的值,并把它插到 id="result" 的元素中

上例也可这样写:

// StorelocalStorage.lastname = "Smith";// Retrieve 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 = "You have clicked the button " + localStorage.clickcount + " time(s)."; 亲自试一试 » sessionStorage 对象

sessionStorage对象等同 localStorage 对象,不同之处在于只对一个 session 存储数据。如果用户关闭具体的浏览器标签页,数据也会被删除。

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

实例 if (sessionStorage.clickcount) {  sessionStorage.clickcount = Number(sessionStorage.clickcount) + 1;} else {  sessionStorage.clickcount = 1;} document.getElementById("result").innerHTML = "You have clicked the button " + sessionStorage.clickcount + " time(s) in this session."; 亲自试一试 » ❮ 上一节 下一节 ❯


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有