cookie
是客户端用来存储数据的,它既能够在客户端设置也能够在服务器端设置。cookie
会跟随任意HTTP
请求一块儿发送html
html5
标准中的Web Storage
包括了两种存储方式:sessionStorage
和localStorage
sessionStorage
用于本地存储一个会话中的数据,这些数据只有在同一个会话中的页面才能访问而且当会话结束后数据也随之销毁。所以sessionStorage
仅仅是会话级别的存储
而localStorage
用于持久化的本地存储,除非主动删除数据,不然数据是永远不会过时的html5
Web Storage
和Cookie
类似都是客户端用来存储数据的,区别是它是为了更大容量存储设计的Cookie
的大小是受限的,最多只能存储4KB
的数据;而且每次你请求一个新的页面的时候,Cookie
都会被发送过去,这样无形中浪费了带宽;再有就是不安全,很容易被拦截者截取进行篡改Web Storage
拥有setItem
、getItem
、removeItem
、clear
等方法,不像cookie
须要本身封装setCookie
、getCookie
等方法
可是Cookie
也是不能够或缺的:Cookie
的做用是与服务器进行交互,做为HTTP
规范的一部分而存在 ,而Web Storage
仅仅是为了在本地存储数据而生web
setItem
安全
sessionStorage.setItem("name","leoyaojy"); localStorage.setItem("website","luckyw.cn");
getItem
服务器
sessionStorage.getItem("name"); //leoyaojy localStorage.getItem("website"); //luckyw.cn
removeItem
cookie
sessionStorage.removeItem("name"); localStorage.removeItem("website");
clear
session
sessionStorage.clear(); localStorage.clear();
其余操做方法:点操做
和[]
设计
sessionStorage.name = "leoyaojy"; console.log(sessionStorage["name"]); localStorage["website"] = "luckyw.cn"; console.log(localStorage.website);
key()
和length
遍历数据code
for (var i=0, len = localStorage.length; i<len; i++){ var key = localStorage.key(i); var value = localStorage.getItem(key); console.log(key + "=" + value); }