一、区别
相信很多人都见过这两个关于HTML5的新名词!
HTML5种的web storage包含两种存储方式:localStorage和sessionStorage,这两种方式存储的数据不会自动发给服务器,仅仅是本地保存,有大小限制。
localStorage是持久化的本地保存,除非主动删除,不然会一直存在,而且在所有的同源窗口中都是可以共享的;
sessionStorage是会话级别的本地保存,比如一个页面关闭的时候该页面设置的sessionStorage数据会自动消失,在不同浏览器窗口不会共享的,即使是同一个浏览器的同一个页面。
两者拥有一些共同的方法:
window.localStorage.setItem(key,value);//设置指定key的数据(JSON格式) window.localStorage.getItem(key);//获取指定key的数据 window.localStorage.removeItem(key);//删除指定key的数据 window.localStorage.clear();//清空所有的存储数据 window.sessionStorage.setItem(key,value); window.sessionStorage.getItem(key); window.sessionStorage.removeItem(key); window.sessionStorage.clear();
二、如何测试
1、最简单的打开浏览器在console里直接输入测试(localStorage)
在你没有执行removeItem和clear()之前浏览器的resources下是能够清楚的看到你所设置的值!即使你关闭该页面重新打开还是可以看到的。
2、更好点的测试,简单封装(sessionStorage)
var KEY='todo'; var Store={ save:function(items){ return window.sessionStorage.setItem(KEY,JSON.stringify(items)); }, fetch:function(){ return JSON.parse(window.sessionStorage.getItem(KEY)||'[]'); } } var s={'name':'九成'}; Store.save(s); var x=Store.fetch(); console.log(x);//输出:Object {name: "九成"}
当你关闭该测试页面数据自动消失。
3、es6的
let NewKey='youType'; let object={ save(items){ return window.sessionStorage.setItem(KEY,JSON.stringify(items)); }, fetch(){ return JSON.parse(window.sessionStorage.getItem(KEY)||'[]'); } }; object.save({'name':'JACK'}); let you=object.fetch(); console.log(you.name);//JACK
如果你更多见解请留下脚印.....