基本概念
cookie:是网景公司的前雇员在1993年发明。它的主要用于保存登陆信息,比如登陆某个网站市场可以看到'记住密码’,这就是通过在cookie中存入一段辨别用户身份的数据来实现的。
sessionStorage:会话,是可以将一部分数据在当前会话中保存下来,刷新页面数据依旧存在。但是页面关闭后,sessionStorage中的数据就会被清空。
localStorage:是HTML5标准中新加入的技术,当然早在IE6时代就有一个userData的东西用于本地存储,而当时考虑到浏览器的兼容性,更通用的方案是使用flash。如今localStorage被大多数浏览器所支持。
三者区别
1)存储大小
cookie:一般不超过4K(因为每次http请求都会携带cookie、所以cookie只适合保存很小的数据,如会话标识)
sessionStorage:5M或者更大
localStorage:5M或者更大
2)数据有效期
cookie:一般由服务器生成,可以设置失效时间;若没有设置时间,关闭浏览器cookie失效,若设置了时间,cookie就会存放在硬盘里,过期才失效
sessionStorage:仅在当前浏览器窗口关闭之前有效,关闭页面或者浏览器会被清除
localStorage:永久有效,窗口或者浏览器关闭也会一直保存,除非手动永久清除,因此用作持久数据
3)作用域
cookie:在所有同源窗口中都是共享的
sessionStorage:在同一个浏览器窗口是共享的(不同浏览器、同一个页面也是不共享的)
localStorage:在所有同源窗口中都是共享的
4)通信
ccokie:十种携带在同源的http请求中,即使不需要,故cookie在浏览器和服务器之间来回传递;如果使用cookie保存过多数据会造成性能问题
sessionStorage:仅在客户端(即浏览器)中保存,不参与和服务器的通信;不会自动把数据发送给服务器,仅在本地保存
localStorage:仅在客户端(即浏览器)中保存,不参与和服务器的通信;不会自动把数据发送给服务器,仅在本地保存
5)易用性
cookie:需要自己进行封装,原生的cookie接口不够友好
sessionStorage:原生接口可以接受,可以封装来对Object和Array有更好的支持
localStorage:原生接口可以接受,可以封装来对Object和Array有更好的支持
应用场景
cookie:判断用户是否登录过网站,以便实现下次自动登录或记住密码;保存事件信息等
sessionStorage:敏感账号一次性登录;单页面用的较多(sessionStorage 可以保证打开页面时 sessionStorage 的数据为空)
localStorage:常用于长期登录(判断用户是否已登录),适合长期保存在本地的数据
Cookie使用方法:
JavaScript可以用 document.cookie 属性创建、读取、删除cookie
创建cookie,还可以添加有效日期(UTC时间)。默认情况下,浏览器关闭后会删除,还可以通过path,告知路径:
1
|
document.cookie= "username=kbin; expires=Sun, 31 Dec 2017 12:00:00 UTC;path=/" |
通过JavaScript读取cookie,同时会以一条字符串的形式返回所有cookie,比如:cookie2=value2
1
|
var x=document.cookie |
通过JavaScript改变cookie
1
|
document.cookie= "username=kbin2; expires=Sun, 31 Dec 2017 12:00:00 UTC;path=/" |
通过JavaScript删除cookie,删除非常简单,只需将expires 参数设置为过去的日期即可
1
|
document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;" ; |
还可借用cookie第三方插件库,例如: jquery.cookie.js
创建一个会话cookie:$.cookie('cookieName','cookieValue');
注:当没有指明cookie时间时,所创建的cookie有效期默认到用户浏览器关闭止,故被称为会话cookie。
创建一个持久并带有效路径的cookie:$.cookie(‘cookieName’,'cookieValue’,{expires:7,path:’/'});
注:当指明时间时,故称为持久cookie,并且有效时间为7天。
如果不设置有效路径,在默认情况下,只能在cookie设置当前页面读取该cookie,cookie的路径用于设置能够读取cookie的顶级目录。
读取cookie:$.cookie('the_cookie'); // cookie存在 => 'the_value'
$.cookie('not_existing'); // cookie不存在 => null
删除cookie,通过传递null作为cookie的值即可:$.cookie('the_cookie', null);
localstorage、sessionstorage有相同的使用api
localStorage.setItem("key","value") //以"key"为名称存储一个值"value"
localStorage.getItem("key")//获取名称为"key"的值
localStorage.removeItem("key")//删除名称为"key"的信息
localStorage.clear() //清空localstorage中所有的信息