WEB应用的快速发展,是的本地存储一些数据也成为一种重要的需求,实现的方案也有很多,最普通的就是cookie了,大家也经常都用,但是cookie的缺点是显而易见的,其他的方案比如:IE6以上的userData,Firefox下面的globalStorage,以及Flash的本地存储,除了Flash之外,其他的几个都有一些兼容性的问题。
Web Storage实际上由两部分组成:sessionStorage与localStorage。
sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才能访问并且当会话结束后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。
localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。
语法:
XML <Prefix: CustomTag ID=sID STYLE="behavior:url('#default#userData')" />
HTML <ELEMENT STYLE="behavior:url('#default#userData')" ID=sID>
Scripting object .style.behavior = "url('#default#userData')"
object .addBehavior ("#default#userData")
属性:
expires 设置或者获取 userData behavior 保存数据的失效日期。
XMLDocument 获取 XML 的引用。
方法:
getAttribute() 获取指定的属性值。
load(object) 从 userData 存储区载入存储的对象数据。
removeAttribute() 移除对象的指定属性。
save(object) 将对象数据存储到一个 userData 存储区。
setAttribute() 设置指定的属性值。
方法:
localStorage.getItem(key):获取指定key本地存储的值
localStorage.setItem(key,value):将value存储到key字段
localStorage.removeItem(key):删除指定key本地存储的值
一、什么是localStorage、sessionStorage
在HTML5中,新加入了一个localStorage特性,这个特性主要是用来作为本地存储来使用的,解决了cookie存储空间不足的问题(cookie中每条cookie的存储空间为4k),localStorage中一般浏览器支持的是5M大小,这个在不同的浏览器中localStorage会有所不同。
二、localStorage的优势与局限
localStorage的优势
1、localStorage拓展了cookie的4K限制
2、localStorage会可以将第一次请求的数据直接存储到本地,这个相当于一个5M大小的针对于前端页面的数据库,相比于cookie可以节约带宽,但是这个却是只有在高版本的浏览器中才支持的
localStorage的局限
1、浏览器的大小不统一,并且在IE8以上的IE版本才支持localStorage这个属性
2、目前所有的浏览器中都会把localStorage的值类型限定为string类型,这个在对我们日常比较常见的JSON对象类型需要一些转换
3、localStorage在浏览器的隐私模式下面是不可读取的
4、localStorage本质上是对字符串的读取,如果存储内容多的话会消耗内存空间,会导致页面变卡
5、localStorage不能被爬虫抓取到
localStorage与sessionStorage的唯一一点区别就是localStorage属于永久性存储,而sessionStorage属于当会话结束的时候,sessionStorage中的键值对会被清空
这里我们以localStorage来分析
三、localStorage的使用
localStorage的浏览器支持情况:
data:image/s3,"s3://crabby-images/2210b/2210b9bb3eba9e95d8aaa6165e3167ed937b7519" alt=""
这里要特别声明一下,如果是使用IE浏览器的话,那么就要UserData来作为存储,这里主要讲解的是localStorage的内容,所以userData不做过多的解释,而且以博主个人的看法,也是没有必要去学习UserData的使用来的,因为目前的IE6/IE7属于淘汰的位置上,而且在如今的很多页面开发都会涉及到HTML5\CSS3等新兴的技术,所以在使用上面一般我们不会去对其进行兼容
首先在使用localStorage的时候,我们需要判断浏览器是否支持localStorage这个属性
data:image/s3,"s3://crabby-images/1150b/1150b7dfeb651e884e98351bc3f78958369d9415" alt=""
data:image/s3,"s3://crabby-images/00f70/00f70c5dc2ab4b141c6ae17e2debc933b510be15" alt=""
if(!window.localStorage){ alert("浏览器支持localstorage");returnfalse; }else{//主逻辑业务
}
data:image/s3,"s3://crabby-images/bf371/bf37113e52f872514c70b6f2c880a85ba0a6329a" alt=""
data:image/s3,"s3://crabby-images/56387/56387012849a7cc44b978632e61967d739e236be" alt=""
localStorage的写入,localStorage的写入有三种方法,这里就一一介绍一下
data:image/s3,"s3://crabby-images/3118f/3118fcc4aea030051d2bea97406c00943336efb3" alt=""
data:image/s3,"s3://crabby-images/ec4af/ec4af56272f26394e7493785ff5da56f9806610d" alt=""
if(!window.localStorage){ alert("浏览器支持localstorage");returnfalse; }else{var storage=window.localStorage;//写入a字段 storage["a"]=1;//写入b字段 storage.a=1;//写入c字段 storage.setItem("c",3); console.log(typeof storage["a"]); console.log(typeof storage["b"]); console.log(typeof storage["c"]);
}
data:image/s3,"s3://crabby-images/52327/5232785bbed8ed18e5c77177a7a66c157f767cfa" alt=""
data:image/s3,"s3://crabby-images/45380/4538038b3630f68eed2b4434c342f95e3b8e86a0" alt=""
运行后的结果如下:
data:image/s3,"s3://crabby-images/a74d2/a74d2d06db6b5bc1a4e4bce2c53e73138f8d332b" alt=""
这里要特别说明一下localStorage的使用也是遵循同源策略的,所以不同的网站直接是不能共用相同的localStorage
最后在控制台上面打印出来的结果是:
data:image/s3,"s3://crabby-images/a46cf/a46cff1beff1b20fcb4c5e20ce7e8298e8df10ac" alt=""
不知道各位读者有没有注意到,刚刚存储进去的是int类型,但是打印出来却是string类型,这个与localStorage本身的特点有关,localStorage只支持string类型的存储。
localStorage的读取
data:image/s3,"s3://crabby-images/8a68f/8a68fae5c62d870d990daa836cbfa360830b91aa" alt=""
data:image/s3,"s3://crabby-images/29d38/29d38a9761d479095f8e227602d746360efec38b" alt=""
if(!window.localStorage){ alert("浏览器支持localstorage"); }else{var storage=window.localStorage;//写入a字段 storage["a"]=1;//写入b字段 storage.a=1;//写入c字段 storage.setItem("c",3); console.log(typeof storage["a"]); console.log(typeof storage["b"]); console.log(typeof storage["c"]);//第一种方法读取var a=storage.a; console.log(a);//第二种方法读取var b=storage["b"]; console.log(b);//第三种方法读取var c=storage.getItem("c");
console.log(c);
}
data:image/s3,"s3://crabby-images/ec378/ec3786eddaf8e280740a397ee8cf9e7cbd4c2826" alt=""
data:image/s3,"s3://crabby-images/827ae/827aef4d195f131ac264dd1383a9e1fef78e5f05" alt=""
这里面是三种对localStorage的读取,其中官方推荐的是getItem\setItem这两种方法对其进行存取,不要问我这个为什么,因为这个我也不知道
我之前说过localStorage就是相当于一个前端的数据库的东西,数据库主要是增删查改这四个步骤,这里的读取和写入就相当于增、查的这两个步骤
下面我们就来说一说localStorage的删、改这两个步骤
改这个步骤比较好理解,思路跟重新更改全局变量的值一样,这里我们就以一个为例来简单的说明一下
data:image/s3,"s3://crabby-images/b42a3/b42a3f3b66cf32012cb73bfb90a80f2816b63026" alt=""
data:image/s3,"s3://crabby-images/39591/395916754d0be247c3fa69b0036e01ae720ecd80" alt=""
if(!window.localStorage){ alert("浏览器支持localstorage"); }else{var storage=window.localStorage;//写入a字段 storage["a"]=1;//写入b字段 storage.b=1;//写入c字段 storage.setItem("c",3); console.log(storage.a);//console.log(typeof storage["a"]);//console.log(typeof storage["b"]);//console.log(typeof storage["c"]);/*分割线*/storage.a=4;
console.log(storage.a);
}
data:image/s3,"s3://crabby-images/4da91/4da91248ea052b41c6f11287c6ff3c14fd238ce7" alt=""
data:image/s3,"s3://crabby-images/b6a8d/b6a8d7970d72792a7d1053915f906de15629a3bd" alt=""
这个在控制台上面我们就可以看到已经a键已经被更改为4了
localStorage的删除
1、将localStorage的所有内容清除
data:image/s3,"s3://crabby-images/f377f/f377fde4ce2b306ddc714577422b7a62250faa99" alt=""
data:image/s3,"s3://crabby-images/ef9e2/ef9e2ab48ab1211c11f92ea75a36b190c7d086c6" alt=""
var storage=window.localStorage; storage.a=1; storage.setItem("c",3);
console.log(storage);
storage.clear();
console.log(storage);
data:image/s3,"s3://crabby-images/77b73/77b73ce7200035a07205ab74ed2f9a856acad185" alt=""
data:image/s3,"s3://crabby-images/5c493/5c493ed18a5f12e81aaeef3cfc0cbd39541f49e5" alt=""
2、 将localStorage中的某个键值对删除
data:image/s3,"s3://crabby-images/bef19/bef19ba208b99294c9ba66d60ef3ca131d99be1d" alt=""
data:image/s3,"s3://crabby-images/9ca10/9ca10ffac5462bac25095d6464a62ed3e555e3b5" alt=""
var storage=window.localStorage; storage.a=1; storage.setItem("c",3); console.log(storage); storage.removeItem("a");
console.log(storage.a);
data:image/s3,"s3://crabby-images/97a1b/97a1b1537a5f820b164f87dbf9504904ebb10d35" alt=""
data:image/s3,"s3://crabby-images/9a5b1/9a5b1c86a217506c7507f00caae9306a11df4084" alt=""
控制台查看结果
data:image/s3,"s3://crabby-images/087d9/087d91e464118647e6d0acd2a2cc345f2ea40935" alt=""
localStorage的键获取
data:image/s3,"s3://crabby-images/8de70/8de70cd98e4daf0d8fd4376e719d31f06f994fda" alt=""
data:image/s3,"s3://crabby-images/46916/4691685137ae886b529d0ac52fa3e9a211c35a6a" alt=""
var storage=window.localStorage; storage.a=1; storage.setItem("c",3);for(var i=0;i
console.log(key);
}
data:image/s3,"s3://crabby-images/11e42/11e42cc6aea9973a4c43366911a8fbfada1f0867" alt=""
data:image/s3,"s3://crabby-images/e57bd/e57bd5cd22a53f53bde7e8dd67ca4799c2773db7" alt=""
使用key()方法,向其中出入索引即可获取对应的键
四、localStorage其他注意事项
一般我们会将JSON存入localStorage中,但是在localStorage会自动将localStorage转换成为字符串形式
这个时候我们可以使用JSON.stringify()这个方法,来将JSON转换成为JSON字符串
示例:
data:image/s3,"s3://crabby-images/57984/5798457f6a4f71d2a6395646bbc7bcf437fab5cc" alt=""
data:image/s3,"s3://crabby-images/f99b4/f99b4f424af345353c0920a4a05d8f90f8427aa8" alt=""
if(!window.localStorage){ alert("浏览器支持localstorage"); }else{var storage=window.localStorage;var data={ name:'xiecanyong', sex:'man', hobby:'program'};var d=JSON.stringify(data); storage.setItem("data",d);
console.log(storage.data);
}
data:image/s3,"s3://crabby-images/95489/95489a0d4334271b02e183329cedcbbf1afcdf4a" alt=""
data:image/s3,"s3://crabby-images/7a15d/7a15db55473bad8e1b6144f9e761bab258834b5d" alt=""
读取之后要将JSON字符串转换成为JSON对象,使用JSON.parse()方法
data:image/s3,"s3://crabby-images/dab73/dab736e435082ecc63747c21f2c302fe08b90046" alt=""
var storage=window.localStorage;var data={ name:'xiecanyong', sex:'man', hobby:'program'};var d=JSON.stringify(data); storage.setItem("data",d);//将JSON字符串转换成为JSON对象输出var json=storage.getItem("data");var jsonObj=JSON.parse(json); console.log(typeof jsonObj);
网友评论