• 售前

  • 售后

热门帖子
入门百科

突袭HTML5之Javascript API扩展3—当地存储全新体验

[复制链接]
特朗普大爷 显示全部楼层 发表于 2021-10-25 19:03:18 |阅读模式 打印 上一主题 下一主题
为什么要存数据到客户端?
存储数据在客户端可以办理很多的问题和淘汰不须要的传输数据:
1. 能生存步调的状态:用户关闭欣赏器再打开后能知道他工作到哪了。
2. 能缓存数据:很多不会厘革的数据根本没须要每次都从服务端获取。
3. 能生存用户的喜欢:这种数据通常不需要存在服务端。
从前的做法
在HTML5本地存储之前,假如我们想在客户端生存持久化数据,有这么几个选择:
1. HTTP cookie。HTTP cookie的缺点很显着,最多只能存储4KB的数据,每个HTTP请求都会被传送回服务器,明文传输(除非你利用SSL)。
2. IE userData。userData是微软在上世纪90年代的欣赏器大战时推出的本地存储方案,借助DHTML的behaviour属性来存储本地数据, 允许每个页面最多存储64K数据,每个站点最多640K数据,userData的缺点显而易见,它不是Web标准的一部分,除非你的步调只需要支持IE, 否则它根本没什么用处。
3. Flash cookie。Flash cookie实际上和HTTP cookie并不是一回事,大概它的名字应该叫做"Flash本地存储”,Flash cookie默认允许每个站点存储不超过100K的数据,假如超出了,Flash会自动向用户请求更大的存储空间,借助Flash的 ExternalInterface接口,你可以很轻松地通过Javascript操作Flash的本地存储。Flash的问题很简单,就是由于它是 Flash。
4. Google Gears。Gears是Google在07年发布的一个开源欣赏器插件,旨在改进各大欣赏器的兼容性,Gears内置了一个基于SQLite的嵌入式 SQL数据库,并提供了统一API对数据库进行访问,在取得用户授权之后,每个站点可以在SQL数据库中存储不限大小的数据,Gears的问题就是 Google本身都已经不用它了。
眼花缭乱的各种技术导致的就是欣赏器的兼容性问题。这里各人用的最多的大概就是cookie了。
HTML5中的全新体验
针对以上的问题,HTML5中给出了更加抱负的办理方案:假如你需要存储的只是简单的用key/value对即可办理的数据,则可以利用Web Storage。
与Cookie相比,Web Storage存在不少的上风,概括为以下几点:
1. 存储空间更大:IE8下每个独立的存储空间为10M,其他欣赏器实现略有不同,但都比Cookie要大很多。
2. 存储内容不会发送到服务器:当设置了Cookie后,Cookie的内容会随着请求一并发送的服务器,这对于本地存储的数据是一种带宽浪费。而Web Storage中的数据则仅仅是存在本地,不会与服务器发生任何交互。
3. 更多丰富易用的接口:Web Storage提供了一套更为丰富的接口,使得数据操作更为简便。
4. 独立的存储空间:每个域(包括子域)有独立的存储空间,各个存储空间是完全独立的,因此不会造成数据杂乱。
Web Storage分类
Web Storage实际上由两部分组成:sessionStorage与localStorage。
sessionStorage用于本地存储一个会话(session)中的数据,这些数据只有在同一个会话中的页面才气访问而且当会话竣事后数据也随之销毁。因此sessionStorage不是一种持久化的本地存储,仅仅是会话级别的存储。
localStorage用于持久化的本地存储,除非主动删除数据,否则数据是永世不会逾期的。
查抄是否支持Web Storage
Web Storage在各大主流欣赏器中都支持了,但是为了兼容老的欣赏器,还是要查抄一下是否可以利用这项技术。
第一种方式:通过查抄Storage对象是否存在来查抄欣赏器是否支持Web Storage:

复制代码代码如下:
if(typeof(Storage)!=="undefined"){
// Yes! localStorage and sessionStorage support!
// Some code.....
} else {
// Sorry! No web storage support..
}

第二种方式就是分别查抄各自的对象,比方查抄localStorage是否支持:

复制代码代码如下:
if (typeof(localStorage) == 'undefined' ) {
alert('Your browser does not support HTML5 localStorage. Try upgrading.');
} else {
// Yes! localStorage and sessionStorage support!
// Some code.....
}
大概:
if('localStorage' in window && window['localStorage'] !== null){
// Yes! localStorage and sessionStorage support!
// Some code.....
} else {
alert('Your browser does not support HTML5 localStorage. Try upgrading.');
}
大概
if (!!localStorage) {
// Yes! localStorage and sessionStorage support!
// Some code.....
} else {
alert('Your browser does not support HTML5 localStorage. Try upgrading.');
}

很显然第一个方式最直接,也最简单。
Web Storage的利用
Web Storage中存储的是键值对,而且欣赏器会以字符串方式存储。记取在须要的时候将他们转为其他格式。
sessionStorage与localStorage除了用途不同外,成员列表是一样的:

复制代码代码如下:
key = value: 存贮键值对
setItem(key, value): 存贮键值对
getItem(key): 取键值对
removeItem(key):移除全部键值对
clear():清空全部键值对
length:键值对的数量

这里还是要强调一下:setItem(key,value)方法中的value类型,理论上可以是任意类型,不过实际上欣赏器会调用value的toString方法来获取其字符串值并存储到本地,因此假如是自界说的类型则需要本身界说故意义的toString方法。比方下面的例子结合JSON.stringify利用:

复制代码代码如下:
var person = {'name': 'rainman', 'age': 24};
localStorage.setItem("me", JSON.stringify(person));
JSON.parse(localStorage.getItem('me')).name; // 'rainman'
/**
* JSON.stringify,将JSON数据转化为字符串
* JSON.stringify({'name': 'fred', 'age': 24}); // '{"name":"fred","age":24}'
* JSON.stringify(['a', 'b', 'c']); // '["a","b","c"]'
* JSON.parse,反解JSON.stringify
* JSON.parse('["a","b","c"]') // ["a","b","c"]
*/

此外,添加键值对的时候,假如添加的数量比力多,比力保险的做法是去查抄是否有超出限额的非常:

复制代码代码如下:
try {
localStorage.setItem(itemId, values.join(';'));
} catch (e) {
if (e == QUOTA_EXCEEDED_ERR) {
alert('Quota exceeded!');
}
}

Web Storage的方法非常简单,下面的示例是统计button点击的次数的:

复制代码代码如下:
<!DOCTYPE html>
<html>
<head>
<script>
function clickCounter()
{
if(typeof(Storage)!=="undefined")
{
if (localStorage.clickcount)
{
localStorage.clickcount=Number(localStorage.clickcount)+1;
}
else
{
localStorage.clickcount=1;
}
document.getElementById("result").innerHTML="You have clicked the button " + localStorage.clickcount + " time(s).";
}
else
{
document.getElementById("result").innerHTML="Sorry, your browser does not support web storage...";
}
}
</script>
</head>
<body>
<p><button  type="button">Click me!</button></p>
<div id="result"></div>
<p>Click the button to see the counter increase.</p>
<p>Close the browser tab (or window), and try again, and the counter will continue to count (is not reset).</p>
</body>
</html>

在上面的例子中,你可以把localStorage换成sessionStorage,点击频频button然后验证在关闭欣赏器前后的效果。
存在的问题
Web Storage的缺陷重要会集在其安全性方面,具体表如今以下两点:
1. 欣赏器会为每个域分配独立的存储空间,即脚本在域A中是无法访问到域B中的存储空间的,但是欣赏器却不会查抄脚本地点的域与当前域是否雷同。即在域B中嵌入域A中的脚本依然可以访问域B中的数据。
2. 存储在本地的数据未加密而且永世不会逾期,极易造成隐私泄漏。
此外,更多的安全相关的问题请参看后面实用参考中的链接。
其他规范一览(仅供相识,说不定什么时候就没了)
Web Database
在老的HTML5提议中,假如你需要存储复杂的数据则可以利用Web Database,可以像客户端步调一样利用SQL(Web Database标准已被废弃,这里就是简单提一下);
globalStorage
这个也是html5中提出来,在欣赏器关闭以后,利用globalStorage存储的信息仍可以或许保留下来,localStorage一样,域中任何一个页面存储的信息都能被全部的页面共享, 不过如今只有FireFox支持。
根本语法:
• globalStorage['developer.mozilla.org'] —— 在developer.mozilla.org下面全部的子域都可以通过这个命名空间存储对象来进行读和写。
• globalStorage['mozilla.org'] —— 在mozilla.org域名下面的全部网页都可以通过这个命名空间存储对象来进行读和写。
• globalStorage['org'] —— 在.org域名下面的全部网页都可以通过这个命名空间存储对象来进行读和写。
• globalStorage[''] —— 在任何域名下的任何网页都可以通过这个命名空间存储对象来进行读和写
方法属性:
• setItem(key, value) —— 设置或重置 key 值。
• getItem(key) —— 获取 key 值。
• removeItem(key) —— 删除 key 值。
• 设置 key 值:window.globalStorage["planabc.net"].key = value;
• 获取 key 值:value = window.globalStorage["planabc.net"].key;
其它特征:
• 逾期时间同 localStorage,其它的一些特性也和localStorage相似。
• 如今Firefox只支持当前域下的globalStorage存储, 假如利用公用域会导致一个这样一个雷同的错误“Security error” code: “1000”。
IndexedDB
末了我们要先容的就是IndexedDB了,相比其他两个规范,如今只有Firefox实现了IndexedDB(趁便提一下,Mozilla表现它们永世不会去实现Web SQL Database),不过Google已经表现正在思量在Chrome中加入IndexDB支持。
IndexedDB引入了一个object store的概念,这有点像是一个SQL Database,你可以在“数据库”中存储“记录”,而且每条“记录”可以拥有很多“字段",每个字段都有一个特定的数据类型,你可以选择记录的子集, 并利用“光标”进行遍历,同时object store中的全部变动都是基于“变乱”的。
更多的信息参看后面利用参考中讲述FireFox中IndexedDB的文档。
实用参考:
官方文档:http://www.w3schools.com/html5/
草根技术分享:https://www.jb51.net/w3school/html5/
本地存储的安全性:http://www.mhtml5.com/2012/03/4586.html
FireFox的实行特性IndexedDB:https://developer.mozilla.org/en-US/docs/IndexedDB

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作