HTML5 本地存储

什么是 HTML 本地存储?

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

浏览器支持

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

API
Web Storage4.08.03.54.011.5

HTML 本地存储对象

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

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

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

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

localStorage 对象

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

实例
  1. <!DOCTYPE html>
  2. <html>
  3. <body>
  4. <div id="result"></div>
  5. <script>
  6. // Check browser support
  7. if (typeof(Storage) !== "undefined") {
  8. // Store
  9. localStorage.setItem("lastname", "Gates");
  10. // Retrieve
  11. document.getElementById("result").innerHTML = localStorage.getItem("lastname");
  12. } else {
  13. document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
  14. }
  15. </script>
  16. </body>
  17. </html>
实例解释:

创建 localStorage 名称/值对,其中:name="lastname",value="Gates"

取回 "lastname" 的值,并把它插到 id="result" 的元素中

上例也可这样写:

  1. // 存储
  2. localStorage.lastname = "Gates";
  3. // 取回
  4. document.getElementById("result").innerHTML = localStorage.lastname;

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

  1. localStorage.removeItem("lastname");

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

下面的例子对用户点击按钮的次数进行计数。在代码中,值字符串被转换为数值,依次对计数进行递增:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script>
  5. function clickCounter() {
  6. if(typeof(Storage) !== "undefined") {
  7. if (localStorage.clickcount) {
  8. localStorage.clickcount = Number(localStorage.clickcount)+1;
  9. } else {
  10. localStorage.clickcount = 1;
  11. }
  12. document.getElementById("result").innerHTML = "您已经点击这个按钮 " + localStorage.clickcount + " 次。";
  13. } else {
  14. document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
  15. }
  16. }
  17. </script>
  18. </head>
  19. <body>
  20. <p><button onclick="clickCounter()" type="button">请点击这里!</button></p>
  21. <div id="result"></div>
  22. <p>请点击按钮使计数器递增。</p>
  23. <p>请关闭浏览器或标签页,然后再试一次,计数器将继续计数(不会重置)。</p>
  24. </body>
  25. </html>

sessionStorage 对象

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

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <script>
  5. function clickCounter() {
  6. if(typeof(Storage) !== "undefined") {
  7. if (sessionStorage.clickcount) {
  8. sessionStorage.clickcount = Number(sessionStorage.clickcount)+1;
  9. } else {
  10. sessionStorage.clickcount = 1;
  11. }
  12. document.getElementById("result").innerHTML = "在本 session 中,您已经点击这个按钮 " + sessionStorage.clickcount + " 次。";
  13. } else {
  14. document.getElementById("result").innerHTML = "抱歉!您的浏览器不支持 Web Storage ...";
  15. }
  16. }
  17. </script>
  18. </head>
  19. <body>
  20. <p><button onclick="clickCounter()" type="button">请点击这里</button></p>
  21. <div id="result"></div>
  22. <p>请点击按钮使计数器递增。</p>
  23. <p>请关闭浏览器或标签页,然后再试一次,计数器会重置。</p>
  24. </body>
  25. </html>