最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

HTML5-WebStorageAPIs的简述

来源:动视网 责编:小采 时间:2020-11-27 15:10:01
文档

HTML5-WebStorageAPIs的简述

HTML5-WebStorageAPIs的简述:1.概述 Web Storage是一种在客户端存储数据的方法。比起Cookie,Web Storage更加安全,能够存储更多对象,而不仅仅是字符串;Web Storage能够存储更大的数据,而不是像只能够存储几KB数据的Cookie;Web Storage还可以减少数据在客户端与服务器间的转
推荐度:
导读HTML5-WebStorageAPIs的简述:1.概述 Web Storage是一种在客户端存储数据的方法。比起Cookie,Web Storage更加安全,能够存储更多对象,而不仅仅是字符串;Web Storage能够存储更大的数据,而不是像只能够存储几KB数据的Cookie;Web Storage还可以减少数据在客户端与服务器间的转


1.概述
Web Storage是一种在客户端存储数据的方法。比起Cookie,Web Storage更加安全,能够存储更多对象,而不仅仅是字符串;Web Storage能够存储更大的数据,而不是像只能够存储几KB数据的Cookie;Web Storage还可以减少数据在客户端与服务器间的转换,减少带宽。
Web Storage的核心是是window对象的两个子对象sessionStorage和localStorage。数据以键值对的形式通过这两个对象存储,这两个对象都实现了storage接口,拥有名称相同的属性和方法,用法也相同。不同之处是二者的存储时间和共享范围。
sessionStorage数据存储时间依赖于存储它的浏览器窗口或选项卡存在的时间,共享范围也是只在产生它的浏览器窗口或选项卡内。
localStorage数据存储时间要超过浏览器的打开时间,除非通过手动或者代码删除,其共享范围是同源(origin)网站的页面间。
许多浏览器不支持sessionStorage访问本地文件系统,因此要通过Web服务器使用。
Web Storage的规范允许存储任何类型数据,但在各浏览器实现上多数值允许存储字符串文本数据,但可以使用Web Storage结合JSON技术存储非文本数据。
更高级的数据存储方法是Web SQL Database,用于基于索引的数据库存储,并具有SQL查询语言SQLite。Web SQL Database目前仅被Safari,Chrome和Opera支持。最终的规范很可能不采用这种方式。另外一种方法是IndexedDB,仅FireFox 4以上版本支持。

2.浏览器支持检测

 function checkStorageSupport() { 
 //sessionStorage 
 
if
 (window.sessionStorage) { 
 alert('This browser supports sessionStorage'); 
 } 
else
 { 
 alert('This browser does NOT support sessionStorage'); 
 } 
 //localStorage 
 if (window.localStorage) { 
 alert('This browser supports localStorage'); 
 } else { 
 alert('This browser does NOT support localStorage'); 
 } 
}

3.Storage接口

 interface Storage { 
 //同源键值对的数目
 readonly attribute unsigned long length; 
 //通过索引获取键,索引从0开始
 getter DOM
String
 
key
(in unsigned long index); 
 //通过键获取值,键若不存在,值将返回
null
 getter any getItem(in DOMString key); 
 //存储键值对,若已存在同名键,则值将被覆盖。若用户关闭了浏览器存储或是已超 //过允许存储的最大值,都将产生QUOTA_EXCEEDED_ERR错误。
 
set
ter creator void setItem(in DOMString key, in any data); 
 //通过键删除值,不存在则什么也不做
 
delete
r void removeItem(in DOMString key); 
 //删除storage中所有键值对,若为空则什么也不做
 void 
clear
(); 
 };

4.读取和存储数据

 //---------------方式一--------------
 //存储数据
 window.sessionStorage.setItem(‘myFirstKey’, ‘myFirstValue’); 
 //读取数据
 alert(window.sessionStorage.getItem(‘myFirstKey’)); 
 //---------------方式二--------------
 //存储数据
 window.sessionStorage.myFirstKey = ‘myFirstValue’;
 //读取数据
 alert(window.sessionStorage.myFirstKey); 
 //---------------方式三--------------
 var varKey = sessionStorage.key(index);
 window.sessionStorage[varKey] = 
new
Value;

5.存储事件
Web Storage与其它页面、浏览器窗口或选项卡、Web Worker间的通信可以通过存储事件来进行。同源的对象都可以监听storage事件。添加storage事件监听方法如下:

 window.addEventListener("storage", displayStorageEvent, true);

6.StorageEvent接口
storage事件对象实现了StorageEvent接口,该接口的声明如下:

 interface StorageEvent : Event { 
 readonly attribute DOMString key; 
 readonly attribute any oldValue; 
 readonly attribute any newValue; 
 readonly attribute DOMString url; 
 //该方法提供了一个对发生storage事件对象的
引用
,这个对象可以是
 //sessionStorage或localStorage
 readonly attribute Storage storageArea;
 };

6.处理最大配额
多数浏览器所允许的Web Storage不超过5MB,为了防止存储数据时产生超出配额的,可以使用捕获QUOTA_EXCEEDED_ERR异常的方法来处理,例如:

try
 {
 sessionStorage["name"] = "Tabatha";
 }
 catch (
exception
)
 {
 if (exception == QUOTA_EXCEEDED_ERR)
 { 
 // we should tell the user their quota has been exceeded. 
 }
 }

文档

HTML5-WebStorageAPIs的简述

HTML5-WebStorageAPIs的简述:1.概述 Web Storage是一种在客户端存储数据的方法。比起Cookie,Web Storage更加安全,能够存储更多对象,而不仅仅是字符串;Web Storage能够存储更大的数据,而不是像只能够存储几KB数据的Cookie;Web Storage还可以减少数据在客户端与服务器间的转
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top