• HTML5 LocalStorage 本地存储


    这几天在看mobile map的框架,在地图初始化之前看到了这样一段代码

    if (window.localStorage) {
          var BYMapWebSiteTemp = window.localStorage.getItem("BYMapWebSiteTemp");
    if (BYMapWebSiteTemp) {
    } else {
          BYMapWebSiteTemp = 0;
    window.localStorage.setItem("WebSiteInitTime", new Date())
    }
    if (navigator.onLine)
           BYMapWebSiteTemp++;
    }
    window.localStorage.setItem("BYMapWebSiteTemp", BYMapWebSiteTemp);
         loaderuri += "?t=" + BYMapWebSiteTemp;
    } else {
     
    }
     
    上网查了一下,window.localStorage 本地存储是html5的新功能,本地存储时一个window对象的一个属性,包括localStoragesessionStorage,后者是用来读取session 信息的,伴随窗口的关闭而消失,以后如果要用到js来获取服务器端session的信息,可以使用这项技术,自己目前还没测试。由于在研究mobile map框架,看了一下本地存储的内容,截图如下
     
    可以看到是以key value的形式来存储数据的,具体用法直接粘贴了
     

    存储数据的方法就是直接给window.localStorage添加一个属性,例如:window.localStorage.a 或者 window.localStorage["a"]。它的读取、写、删除操作方法很简单,是以键值对的方式存在的,如下:

    localStorage.a = 3;//设置a"3"
    localStorage["a"] = "sfsf";//设置a"sfsf",覆盖上面的值
    localStorage.setItem("b","isaac");//设置b"isaac"
    var a1 = localStorage["a"];//获取a的值
    var a2 = localStorage.a;//获取a的值
    var b = localStorage.getItem("b");//获取b的值
    localStorage.removeItem("c");//清除c的值

     

    这里最推荐使用的自然是getItem()setItem(),清除键值对使用removeItem()。如果希望一次性清除所有的键值对,可以使用clear()。另外,HTML5还提供了一个key()方法,可以在不知道有哪些键值的时候使用,如下:

    var storage = window.localStorage;
    function showStorage(){
     for(var i=0;i<storage.length;i++){
      //key(i)获得相应的键,再用getItem()方法获得对应的值
      document.write(storage.key(i)+ " : " + storage.getItem(storage.key(i)) + "<br>");
     }
    }

     
     
  • 相关阅读:
    JAVA 线程安全与同步机制
    JAVA 多线程
    el-table 宽度自适应bug
    详解迭代器Iterator
    理解基本类型的溢出
    理解classpath
    I/O(一):基础知识
    C++: 智能指针
    C++: 值类别与移动语义基础
    CUDA 架构与编程概述
  • 原文地址:https://www.cnblogs.com/lilefordream/p/3042678.html
Copyright © 2020-2023  润新知