Web Storage

Web Storage API 为浏览器提供了一种比cookies更加直观的方式来存储键值对的机制。
sessionStorage:保存在session中,如果用户关掉浏览器,数据会立即丢失。
localStorage:数据保存在客户端本地的硬件设备中,即使浏览器关闭了,数据依然存在。只有当应用本身或者用户手动清理本地存储空间是,数据才会被覆盖或清除。

  • 保存数据:
sessionStorage.setItem(key,value);
  sessionStorage.key = value;
  sessionStorage[key] = value;
  • 读取数据:只要网页时同源的,基于相同的键,我们都能够在其他网页中获得设置在sessionStorage上的数据。
sessionStorage.getItem(key);
sessionStorage.key;
sessionStorage[key];
  • 存储的键值对的数量:
var length = sessionStorage.length;
  • 删除单个数据:
sessionStorage.removeItem(key);
  • 删除所有数据:
sessionStorage.clear();
  • 获取指定位置的键:
sessionStorage.key(index);

Storage事件

无论何时,Storage 对象发生变化时(即创建/更新/删除数据项时,重复设置相同的键值不会触发该事件),StorageEvent事件会触发,与发生改变的窗口同源的每个窗口的window对象上都会触发Web Storage事件。
监听同源窗口的Storage事件:window.addEventListener("storage", displayStorageEvent)

StorageEvent接口:
  • key: key属性包含了存储中被更新或删除的键
  • oldValue: 更新前键对应的数据
  • newValue: 更新后键对应的数据
  • url: Storage事件发生的url地址
  • storageArea:指向发生改变的localStorage
window.addEventListener("storage", function (e) {
    var logged = {
        key: e.key, //key属性包含了存储中被更新或删除的键
        oldValue: e.oldValue,
        newValue: e.newValue,
        url: e.url,
        storageArea: e.storageArea
    }
    console.log(JSON.stringify(logged, null, 2))
})

sessionStorage的作用域是限制在顶层窗口的,因此对sessionStorage的改变只有当有相牵连的窗口的时候才会触发事件

作为简单数据库使用

var data = {
    name: document.getElementById("name").value,
    age: document.getElementById("age").value,
    email: document.getElementById("email").value,
    tel: document.getElementById("tel").value
}
var str = JSON.stringify(data)
sessionStorage.setItem(data.name, str)

你可能感兴趣的:(Web Storage)