HTML5--本地存储Web Storage
Web Storage功能,顾名思义,就是在Web上针对客户端本地储存数据的功能,具体来说Web Storage分为两种;
sessionStorage:
将数据保存在session对象中,所谓session是指用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间,也就是用户浏览这个网站所花费的时间。session对象可以用来保存在这段时间内所要求保存的任何数据。
localStorage:
将数据保存在客户端本地的硬件设备(通常指硬盘,当然可以是其他的硬件设备)中,即是浏览器被关闭了,该数据仍然存在,下次打开浏览器访问网站时,仍然可以继续使用。
sessionStorage与localStorage区别:
这两者的区别在于sessionStorage为临时保存,而localStorage为永久保存。
接下来我们一起看一下:
SessionStorage:
将数据保存在session对象中,所谓session是指用户在浏览某个网站时,从进入网站到浏览器关闭所经过的这段时间会话,也就是用户浏览这个网站所花费的时间就是session的生命周期。session对象可以用来保存在这段时间内所要求保存的任何数据。
此对象主要有两个方法:
保存数据:sessionStorage.setItem(Key, value);
读取数据:sessionStorage.getItem(Key);
Key:表示你要存入的键名称,此名称可以随便命名,可以按照变量的意思来理解。
Value:表示值,也就是你要存入Key中的值,可以按照变量赋值来理解。
使用方法:
保存数据:sessionStorage.setItem("website", "W3Cfuns.com");
读取数据:sessionStorage.getItem("website");
代码案例:
1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta charset="gb2312"> 5 <title>HTML5--本地存储SessionStorage</title> 6 <script type="text/javascript"> 7 window.onload = function() 8 { 9 alert("当你关闭此页面或者关闭浏览器的时候,sessionStorage中保存的数据才会消失,也就是说重新打开此页面的时候,点击获取数据
,将不会显示任何数据,刷新页面无效。\r\n由此可以证明,sessionStorage的生命周期为,某个用户浏览网站时,从进入到离开的这段时间。") 10 11 //首先获得body中的3个input元素 12 var msg = document.getElementById("msg"); 13 var getData = document.getElementById("getData"); 14 var setData = document.getElementById("setData"); 15 16 setData.onclick = function()//存入数据 17 { 18 if(msg.value) 19 { 20 sessionStorage.setItem("data", msg.value); 21 alert("信息已保存到data字段中"); 22 } 23 else 24 { 25 alert("信息不能为空"); 26 } 27 } 28 29 getData.onclick = function()//获取数据 30 { 31 var msg = sessionStorage.getItem("data"); 32 if(msg) 33 { 34 alert("data字段中的值为:" + msg); 35 } 36 else 37 { 38 alert("data字段无值!"); 39 } 40 } 41 } 42 </script> 43 </head> 44 45 <body> 46 <input id="msg" type="text"/> 47 <input id="setData" type="button" value="保存数据"/> 48 <input id="getData" type="button" value="获取数据"/> 49 </body> 50 </html>
LocalStorage:
使用方法与SessionStorage如出一辙,如下代码所示:
此对象主要有两个方法:
保存数据:localStorage.setItem(Key, value);
读取数据:localStorage.getItem(Key);
Key:表示你要存入的键名称,此名称可以随便命名,可以按照变量的意思来理解。
Value:表示值,也就是你要存入Key中的值,可以按照变量赋值来理解。
使用方法:
保存数据:localStorage.setItem("website", "W3Cfuns.com");
读取数据:localStorage.getItem("website");
案例如下:
1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta charset="gb2312"> 5 <title>HTML5--本地存储LocalStorage</title> 6 <script type="text/javascript"> 7 window.onload = function() 8 { 9 alert("当你关闭此页面或者关闭浏览器的时候,localStorage中保存的数据才会消失,也就是说重新打开此页面的时候,点击获取数据,
可以取到数据。") 10 11 //首先获得body中的3个input元素 12 var msg = document.getElementById("msg"); 13 var getData = document.getElementById("getData"); 14 var setData = document.getElementById("setData"); 15 16 setData.onclick = function()//存入数据 17 { 18 if(msg.value) 19 { 20 localStorage.setItem("data", msg.value); 21 alert("信息已保存到data字段中"); 22 } 23 else 24 { 25 alert("信息不能为空"); 26 } 27 } 28 29 getData.onclick = function()//获取数据 30 { 31 var msg = localStorage.getItem("data"); 32 if(msg) 33 { 34 alert("data字段中的值为:" + msg); 35 } 36 else 37 { 38 alert("data字段无值!"); 39 } 40 } 41 } 42 </script> 43 </head> 44 45 <body> 46 <input id="msg" type="text"/> 47 <input id="setData" type="button" value="保存数据"/> 48 <input id="getData" type="button" value="获取数据"/> 49 </body> 50 </html>
新的选择器
document.querySelector("selector");
selector:根据CSS选择器返回第一个匹配到的元素,如果没有匹配到,则返回null;
支持: Chrome 4.0+, FireFox 3.5+, Safari 3.2+, Opera 10.1+, IE 8+
document.querySelectorAll("selector");
selector:根据CSS选择器返回所有匹配到的元素数组,如果没有匹配到,则返回空数组;
支持: Chrome 4.0+, FireFox 3.5+, Safari 3.2+, Opera 10.1+, IE 8+
document.getElementsByClassName("selector");
selector:根据类选择器返回所有匹配到的元素数组,如果没有匹配到,则返回空数组;
支持: Chrome 4.0+, FireFox 3.0+, Safari 3.2+, Opera 10.1+, IE 8+
案例如下:
HTML结构如下:
1 <div class="content"> 2 <ul> 3 <li>实例</li> 4 5 <li class="exp">实例</li> 6 7 <li class="exp">实例</li> 8 9 <li class="exp">实例</li> 10 11 <li>实例</li> 12 13 </ul> 14 15 </div>
1、如果想要获得第一个li元素,我们只需要:
document.querySelector(".content ul li");
2、如果想要获得所有li元素,我们只需要:
document.querySelectorAll(".content ul li");
3、如果想要获得所有class为w3c的li元素,我们只需要:
document.getElementsByClassName("w3c");