首先让咱们先了解一下,什么是cookie,cookie是浏览器提供的一种机制,他将document.cookie的接口提供给JavaScript使其能够对cookie进行控制,但cookie并非JavaScript自己的属性,cookie是储存于用户硬盘的一个文件(测试的时候在FF测试,其余浏览器不支持直接输出cookie)javascript
cookie的做用java
使用cookie须要注意的是跨域
接下来是重点了,那么咱们如何获取cookie呢?在js中为咱们提供了这么一种方法 doucmnet.cookie,返回的是一个字符串,咱们来举个例子浏览器
<script>
document.cookie="userName=user" document.cookie="userName=xiaoming" console.log(document.cookie)//userName=xiaoming; suerNmae=xiaoming </script>
这就是建立了一个cookie,userName表明cookie的名称,user表明cookie的值,若是cookie的名称不存在那么表明从新建立cookie,若是已经存在,表明为cookie从新赋值服务器
接下来咱们开始说一下如何设置和获取以及删除cookiecookie
设置cookie,直接上代码session
<script>
function setCookie(name,value,expDays){ //name 名字 value 值 expDays 过时时间 //首先设置expDays为当前时间 var expDate=new Date; //使用setDate的方法为当前时间加上expDays设置cookie的失效时间 expDate.setDate(expDate.getDate()+expDays); //设置cookie的内容时不能出现空格方,分号等特殊字符,使用escape对内容进行编码 //经过toUTCString方法把日期转换为字符串传入 document.cookie=name+'='+escape(value)+';expires'+expDate.toUTCString(); } </script>
获取cookie,直接上代码性能
<script>
function getCookie(name){ //设置初始位置,检查cookie中有没有这个name var start=document.cookie.indexOf(name+"="); if(start !=-1){ //若是有的话把strat的位置变为由'='开始的位置 start=start+name.length+1; //设置cookie截取到的终点位置,到下一个";"为止 var end=document.cookie.indexOf(";",start); //这里是为了判断若是这个name是cookie的最后一个值的话那么它的value是没有";"的,直接到 cookie的结尾位置便可 if(end==-1) end=document.cookie.length; //将cookie的value的值解码返回 return unescape(document.cookie.substring(start,end)) } //若是该cookie不存在的话直接返回空的字符串 return "" } </script>
删除cookie,这里须要说一下,cookie的删除是由浏览器执行的,在浏览器发现cookie的有效日期已通过期的话会对该条cookie进行删除操做,下面开始代码测试
<script>
//直接回调setCookie的方法,而后将cookie的有效时间向前一天 function removeCookie(name){ setCookie(name,"",-1) } </script>
那么我接下说一下关于localStorage(本地存储)和sessionStorage(会话存储)这两个都是在HTML5中新增长的属性,它们将浏览器的本地存储的大小扩大到了5M,并且从IE8以上的浏览器都开始支持,localStorage指的是将数据存储在浏览器本地,若是不进行清除那么数据会一直存在,sessionStorage表示的是会话存储,若是浏览器关闭那么数据将会被清除,注意传入的必须是字符串格式的,若是想要写入的时候更复杂JSON.parse(localStorage.getItem("a")),那么相应的导出的时候使用localStorage.setItem("a", JSON.stringify(obj))ui
在HTML5中,本地存储是一个window的方法,因此检测的代码以下:
if(window.localStorage){ alert('This browser supports localStorage'); }else{ alert('This browser does NOT support localStorage'); }
这二者的方法,因为用法比较简单,因此直接上代码
<script>
window.localStorage.name="xiaoming";//设置name window.localStorage["name"]="xiaobai";//设置name,注意须要是字符串格式的 localStorage.setItem("name","xiaohong");//设置name console.log(localStorage.name);//最后设置的值覆盖了以前设置的值 console.log(localStorage["name"]);//也是获取localStorage的值,不过记的要传入的是字符串 // localStorage.removeItem("name");//删除指定的localStorage的属性值 localStorage.clear();//清除全部localStarge的属性和值 console.log(localStorage.getItem("name"));//获取特定的localStorage的值,返回的是null console.log(window.localStorage.name);//undefined //推荐使用的方法,setItem,getItem,removeItem,clear </script>
在H5中提供了一个key()方法,用来在不知道键和值得状况下获取全部的键和值,使用方法以下:
<script> var stroage=window.localStorage; function showStorage(){ for(var i=0;i<storage.length;i++){ //key(i)得到相应的键,再用getItem()方法得到对应的值 document.write(storage.key(i)+ " : " + storage.getItem(storage.key(i)) + "<br>"); } } </script>
在H5中新增长了onstorage事件,当本地存储发生改变时,会触发该事件
StorageEvent对象的属性:
来一段代码
<script>
window.onstorage = function (event) { var key = event.key // 被修改的键名 var oldValue = event.oldValue // 旧的值 var newValue = event.newValue // 新的值 var url = event.url // 触发改变的网页的url var storage = event.storageArea // 当前localStorage的引用(当sessionStorage改变时,这里就是当前sessionStorage的引用,好吧扯远了,看不懂能够先无视) } </script>
if (!window.localStorage) { Object.defineProperty(window, "localStorage", new (function () { var aKeys = [], oStorage = {}; Object.defineProperty(oStorage, "getItem", { value: function (sKey) { return sKey ? this[sKey] : null; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "key", { value: function (nKeyId) { return aKeys[nKeyId]; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "setItem", { value: function (sKey, sValue) { if(!sKey) { return; } document.cookie = escape(sKey) + "=" + escape(sValue) + "; expires=Tue, 19 Jan 2038 03:14:07 GMT; path=/"; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "length", { get: function () { return aKeys.length; }, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "removeItem", { value: function (sKey) { if(!sKey) { return; } document.cookie = escape(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/"; }, writable: false, configurable: false, enumerable: false }); Object.defineProperty(oStorage, "clear", { value: function () { if(!aKeys.length) { return; } for (var sKey in aKeys) { document.cookie = escape(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT; path=/"; } }, writable: false, configurable: false, enumerable: false }); this.get = function () { var iThisIndx; for (var sKey in oStorage) { iThisIndx = aKeys.indexOf(sKey); if (iThisIndx === -1) { oStorage.setItem(sKey, oStorage[sKey]); } else { aKeys.splice(iThisIndx, 1); } delete oStorage[sKey]; } for (aKeys; aKeys.length > 0; aKeys.splice(0, 1)) { oStorage.removeItem(aKeys[0]); } for (var aCouple, iKey, nIdx = 0, aCouples = document.cookie.split(/\s*;\s*/); nIdx < aCouples.length; nIdx++) { aCouple = aCouples[nIdx].split(/\s*=\s*/); if (aCouple.length > 1) { oStorage[iKey = unescape(aCouple[0])] = unescape(aCouple[1]); aKeys.push(iKey); } } return oStorage; }; this.configurable = false; this.enumerable = true; })()); }