Web Storage

2016-12-20  本文已影响0人  幸福镰刀

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

sessionStorage.setItem(key,value);
  sessionStorage.key = value;
  sessionStorage[key] = value;
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接口:
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)
上一篇 下一篇

猜你喜欢

热点阅读