HTML 5入门知识(五)
本地存储Web Storage
使用HTML 5的Web Storage功能,可以在客户端存储更多的数据,而且可以实现数据在多个页面中共享甚至是同步。
cookie存储数据的不足
cookie可用于在程序间传递少量的数据,对于web应用来说,它是一个在服务器和客户端之间来回传送文本值的内置机制,服务器可以根据cookie来追踪用户在不同页面的访问信息。正因为其卓越的表现,在目前的web应用中,cookie得到了最为广泛的应用。然而它有一些不足的地方:
1、大小的限制:cookie的大小被限制在4kb。在web的富应用环境中,不能接受文件或者邮件那样的大数据;
2、带宽的限制:只要有涉及cookie的请求,cookie数据都会在服务器和浏览器间来回传送。这样无论访问哪个页面,cookie数据都会消耗网络的带宽;
3、安全风险:由于cookie会频繁地在网络中传送,而且数据在网络上是可见的,因此在不加密的情况下,是有安全风险的;
4、操作复杂:在客户端的浏览器中,使用JavaScript操作cookie数据是比较复杂的。但是服务器可以很方便地操作cookie数据。
使用Web Storage存储的优势
Web Storage可以在客户端保存大量的数据,而且通过其提供的接口,访问数据也非常方便。然而,Web Storage的诞生并不是为了替代cookie,相反,是为了弥补cookie在本地存储中表现的不足。其优势在以下几个方面:
1、存储容量:提供更大的存储量。在Firefox、Chrome、Safari和Opera中,每个网域为5MB;在IE8及以上则每个网域为10MB;
2、零带宽:Web Storage中的数据仅仅是存储在本地,不会与服务器发生任何交互行为,所以不存在网络带宽的占用问题;
3、编程接口:Web Storage听歌了一套丰富的编程接口,使得数据操作更加方便;
4、独立的存储空间:每个域,包括子域都有独立的存储空间,各个存储空间是完全独立的,因此不会造成数据的混乱。
注意:服务器可以访问cookie中的数据,但是不能访问Web Storage中的数据。
会话存储(sessionStorage)与本地存储(localStorage)的区别
cookie和session完全是服务器端可以操作的数据,但是sessionStorage和localStorage则完全是浏览器客户端操作的数据。它们完全继承同一个Storage API,所以sessionStorage和localStorage的编程接口是一样的。sessionStorage和localStorage的主要区别在于数据存在的时间范围和页面范围不同。
时间范围:前者数据会保存到存储它的窗口或标签关闭时;后者的数据生命周期比窗口或浏览器的生命周期长。
页面范围:前者数据只在构建他们的窗口或标签页内可见;后者的数据可被同源的每个窗口或标签页共享。
使用Web Storage
检查浏览器是否支持 Web Storage,如:

设置和获取Storage数据:
sessiongStorage和localStorage作为window的属性,完全继承Storage API,它们提供的操作数据的方法完全相同。
1、保存数据到sessionStorage,如:

2、从sessionStorage中获取数据,如:

3、设置和获取数据的其他写法,对于访问Storage对象还有更简单的方法,根据“键”和“值”的配对关系,直接在sessionStorage对象上设置和获取数据,可完全避免调用setItem()和getItem()方法,如:

这种灵活的使用方法,给编程带来极大的灵活性。当然,对于localStorage来说,同样具有上述设置数据和获取数据的方法。
使用sessionStorage和localStorage实战:

使用Storage对象保存页面内容:


链接:https://cruxf.github.io/WebStorage/sessionStorage.html
存储JSON对象的数据
虽然使用Web Storage可以保持任意的“键/值”对数据,但是一些浏览器把数据限定为字符串类型,而且对于一些复杂结构的数据,管理起来比较混乱。不过对于复杂结构的数据,可以使用现代浏览器都支持的JSON对象来处理。
1、序列化JSON格式的数据
由于Storage是以字符串保存数据的,因此在保存JSON格式的数据之前,需要把JSON格式的数据转换为字符串,称为序列化。可以使用JSON.stringify()序列化JSON格式的数据未字符数据,如:

2、把数据反序列化为JSON格式
如果把存储的Storage中的数据以JSON格式对象去访问,需要把字符串数据转换成JSON格式的数据,称为反序列化。可以使用JSON.parse()反序列化字符串数据未JSON格式的数据,如:

案例:



链接:https://cruxf.github.io/WebStorage/jsonstorage.html
Storage API的事件
有时候,会存在多个网页或标签页同时访问存储数据的情况。为保证修改的数据能够及时反馈到另一个页面,HTML 5的Web Strage内建立一套事件通知机制,会在数据更新时触发。无论监听的窗口是否存储过该数据,只要与执行存储的窗口是同源的,都会触发Web Storage事件。
课外作业:了解本地数据库Web SQL
HTML 5入门知识(五)的更多相关文章
- TypeScript入门知识五(面向对象特性二)
1.泛型(generic) 参数化的类型,一般用来限制集合的内容 class Person { constructor(private name: string) { } work() { }}var ...
- TypeScript入门知识五(面向对象特性一)
1.类(class) 类是TypeScript的核心,使用TypeScript开发时,大部分代码都是写在类里面的. 类的定义 ,属性控制符 public(允许外部访问,也是默认的方式),private ...
- SCARA——OpenGL入门学习五六(三维变换、动画)
OpenGL入门学习(五) 此课为三维变换的内容,比较枯燥.主要是因为很多函数在单独使用时都不好描述其效果, 在前面绘制几何图形的时候,大家是否觉得我们绘图的范围太狭隘了呢?坐标只能从-1到1,还只能 ...
- Python基础入门知识
本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...
- Web前端入门知识
第一阶段:理论知识 第一章:协议理解 第二阶段:了解知识 第二章:前端简介 第三阶段:入门知识 第三章:标签结构 第四章:常用标签 第四阶段:样式搭配 第五章:样式初见 第六章:属性选择 第七章:属性 ...
- Httpd服务入门知识-https(http over ssl)安全配置
Httpd服务入门知识-https(http over ssl)安全配置 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.SSL会话的简化过程 ()客户端发送可供选择的加密方式, ...
- Httpd服务入门知识-Httpd服务常见配置案例之虚拟主机
Httpd服务入门知识-Httpd服务常见配置案例之虚拟主机 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.虚拟主机实现方案 1>.Apache httpd 有三种实现虚 ...
- Httpd服务入门知识-Httpd服务常见配置案例之基于用户账号实现访问控制
Httpd服务入门知识-Httpd服务常见配置案例之基于用户账号实现访问控制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.基于用户的访问控制概述 认证质询: WWW-Auth ...
- Httpd服务入门知识-http协议版本,工作机制及http服务器应用扫盲篇
Httpd服务入门知识-http协议版本,工作机制及http服务器应用扫盲篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Internet与中国 Internet最早来源于美 ...
- 无废话ExtJs 入门教程五[文本框:TextField]
无废话ExtJs 入门教程五[文本框:TextField] extjs技术交流,欢迎加群(201926085) 继上一节内容,我们在表单里加了个两个文本框.如下所示代码区的第42行位置,items: ...
随机推荐
- java的WindowBuilder可视化插件
一直做在安卓用xml作界面,对于java的控件不熟悉,也不习惯用代码做UI尤其是布局. 找了一下发现可以安装windowbuilder来实现java的可视化编程,但是很多资料里的连接都失效了. 刚自己 ...
- MySQL服务器的线程数查看方法
mysql重启命令:/etc/init.d/mysql restart MySQL服务器的线程数需要在一个合理的范围之内,这样才能保证MySQL服务器健康平稳地运行.Threads_created表示 ...
- animate的{queue:false,duration:400}意思
示例:$(document).ready(function(){ $('.tmplS').hover(function(){ $(".cover", this).stop().an ...
- NSException异常处理
异常处理是管理非典型事件(例如未被识别的消息)的过程,此过程将会中断正常的程序执行.如果没有足够的错误处理,遇到非典型事件时,程序可能立刻抛出(或者引发)一种被称之为异常的东西,然后结束运行. 异常的 ...
- Canvas arcTo绘制圆弧
arcTo(x1,y1,x2,y2,r); 当前点x0,y0;圆弧与(x0,y0-x1,y1)相切,与(x1,y1-x2,y2)相切: <!DOCTYPE html> <html l ...
- SimpleDateFormat解析的时候字符串过长问题
竟然不会报错: try { SimpleDateFormat dateFormatFrom = new SimpleDateFormat("yyyyMMddHHmmss"); St ...
- 动态加载css方法实现和深入解析
一.方法引用来源和应用 此动态加载css方法 loadCss,剥离自Sea.js,并做了进一步的优化(优化代码后续会进行分析). 因为公司项目需要用到懒加载来提高网站加载速度,所以将非首屏渲染必需 ...
- Android开发系列之adb常用命令
对于Android开发者来说,如果没有adb的帮助,那肯定就跟少了一只手那样别扭.其实笔者在刚刚学习Android开发的时候,也没有意识到adb的重要性.想想只要用IDE画出界面,然后实现后台的逻辑代 ...
- Word常用实用知识2
纯手打,可能有错别字,使用的版本是office Word 2013 转载请注明出处 http://www.cnblogs.com/hnnydxgjj/p/6296863.html,谢谢. 批注和 ...
- 001.net开发环境与变量
1 .net 技术平台,用来创建互联互通的应用程序 2 应用 嵌入式开发企业级应用 3 .NET Framework 技术:公共语言运行时 .NET Framework的工作模式:.NetC#> ...