zoukankan      html  css  js  c++  java
  • 11

    什么是 HTML 本地存储?

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

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

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

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

    HTML 本地存储对象

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

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

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

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

    <!DOCTYPE html>
    <html>
    <body>

    <div id="result"></div>

    <script>
    // Check browser support
    if (typeof(Storage) !== "undefined") {
    // Store
    localStorage.setItem("lastname", "Gates");
    // Retrieve
    document.getElementById("result").innerHTML = localStorage.getItem("lastname");
    } else {
    document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
    }
    </script>

    </body>
    </html>

    localStorage 对象

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

    <!DOCTYPE html>
    <html>
    <head>
    <script>
    function clickCounter() {
    if(typeof(Storage) !== "undefined") {
    if (localStorage.clickcount) {
    localStorage.clickcount = Number(localStorage.clickcount)+1;
    } else {
    localStorage.clickcount = 1;
    }
    document.getElementById("result").innerHTML = "您已经点击这个按钮 " + localStorage.clickcount + " 次。";
    } else {
    document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
    }
    }
    </script>
    </head>
    <body>
    <p><button onclick="clickCounter()" type="button">请点击这里!</button></p>
    <div id="result"></div>
    <p>请点击按钮使计数器递增。</p>
    <p>请关闭浏览器或标签页,然后再试一次,计数器将继续计数(不会重置)。</p>
    </body>
    </html>

    sessionStorage 对象

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

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

    <!DOCTYPE html>
    <html>
    <head>
    <script>
    function clickCounter() {
    if(typeof(Storage) !== "undefined") {
    if (sessionStorage.clickcount) {
    sessionStorage.clickcount = Number(sessionStorage.clickcount)+1;
    } else {
    sessionStorage.clickcount = 1;
    }
    document.getElementById("result").innerHTML = "在本 session 中,您已经点击这个按钮 " + sessionStorage.clickcount + " 次。";
    } else {
    document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
    }
    }
    </script>
    </head>
    <body>
    <p><button onclick="clickCounter()" type="button">请点击这里</button></p>
    <div id="result"></div>
    <p>请点击按钮使计数器递增。</p>
    <p>请关闭浏览器或标签页,然后再试一次,计数器会重置。</p>
    </body>
    </html>

  • 相关阅读:
    Javascript函数声明和函数表达式
    浅谈getAttribute兼容性
    js数组去重的三种常用方法总结
    说说JSON和JSONP,也许你会豁然开朗
    web安全之跨站请求伪造
    javascript中对象的深度克隆
    三种方式实现元素水平居中显示与固定布局和流式布局概念理解
    js dom element 属性整理(原创)
    ul下的li浮动,如何是ul有li的高度
    js数组去重的4个方法
  • 原文地址:https://www.cnblogs.com/xueqiuxiang/p/12296263.html
Copyright © 2011-2022 走看看