html5 localStorage本地存储_动力节点Java学院整理


Posted in HTML / CSS onJuly 06, 2017

localStorage 即本地存储,可用于长久保存整个网站的数据,保存的数据没有过期时间,直到手动去除。

在JavaScript语言中可通过 window.localStorage 或 localStorage 调用此对象。

特点

1) 同源策略限制。若想在不同页面之间对同一个localStorage进行操作,这些页面必须在同一协议、同一主机名和同一端口下。(IE8和9存储数据仅基于同一主机名,忽略协议(HTTP和HTTPS)和端口号的要求)

2) 只在本地存储。localStorage的数据不会跟随HTTP请求一起发送到服务器,只会在本地生效。

3) 永久保存。保存的数据没有过期时间,直到手动去除。

4) 存储方式。localStorage的存储方式采用key、value的方式。value的值必须为字符串类型(传入非字符串,也会在存储时转换为字符串。true值会转换为"true")。

5) 存储上限限制:不同的浏览器存储的上限也不一样,但大多数浏览器把上限限制在5MB以下。

6) 同浏览器共享。localStorage的数据可以在同一个浏览器的不同标签页的同源页面之间共享。

浏览器最小版本支持

支持localStorage浏览器的最小版本:IE8、Chrome 5。

适用场景

localStorage 比较适用2个地方:

1) 数据比较大的临时保存方案。如在线编辑文章时的自动保存。

2) 多页面访问共同数据。sessionStorage只适用于同一个标签页,localStorage相比而言可以在多个标签页中共享数据。

属性

html5 localStorage本地存储_动力节点Java学院整理readonly int localStorage.length :返回一个整数,表示存储在 localStorage 对象中的数据项(键值对)数量。

方法

html5 localStorage本地存储_动力节点Java学院整理string localStorage.key(int index) :返回当前 localStorage 对象的第index序号的key名称。若没有返回null。

html5 localStorage本地存储_动力节点Java学院整理string localStorage.getItem(string key) :返回键名(key)对应的值(value)。若没有返回null。

html5 localStorage本地存储_动力节点Java学院整理void localStorage.setItem(string key, string value) :该方法接受一个键名(key)和值(value)作为参数,将键值对添加到存储中;如果键名存在,则更新其对应的值。

html5 localStorage本地存储_动力节点Java学院整理void localStorage.removeItem(string key) :将指定的键名(key)从 localStorage 对象中移除。

html5 localStorage本地存储_动力节点Java学院整理void localStorage.clear() :清除 localStorage 对象所有的项。

事件

html5 localStorage本地存储_动力节点Java学院整理storage :当对 localStorage 进行更改时,触发此事件。

在IE 11和Chrome中对此事件有不同的触发机制:

1) 当前页面是否触发:当前页面进行localStorage 操作时,IE 11是当前页面也触发此事件,Chrome 是当前页面不触发此事件。

2) 对localStorage进行重复操作:如存入重复的数据,IE 11是触发此事件,Chrome 是不触发此事件。

存储数据

采用setItem()方法存储

localStorage.setItem('testKey','这是一个测试的value值'); // 存入一个值

通过属性方式存储  

localStorage['testKey'] = '这是一个测试的value值';

获取数据

通过getItem()方法取值

localStorage.getItem('testKey'); // => 返回testKey对应的值

通过属性方式取值

localStorage['testKey']; // => 这是一个测试的value值

存储Json对象

localStorage 也可存储Json对象:存储时,通过JSON.stringify()将对象转换为文本格式;读取时,通过JSON.parse()将文本转换回对象。

var userEntity = {
    name: 'tom',
    age: 22
};
 
// 存储值:将对象转换为Json字符串
localStorage.setItem('user', JSON.stringify(userEntity));
 
// 取值时:把获取到的Json字符串转换回对象
var userJsonStr = localStorage .getItem('user');
userEntity = JSON.parse(userJsonStr);
console.log(userEntity.name); // => tom
HTML / CSS 相关文章推荐
CSS中越界问题的经典解决方案【推荐】
Apr 19 HTML / CSS
CSS3制作hover下划线动画
Mar 27 HTML / CSS
CSS3 mask 遮罩的具体使用方法
Nov 03 HTML / CSS
解决img标签上下出现间隙的方法
Dec 14 HTML / CSS
Html5画布_动力节点Java学院整理
Jul 13 HTML / CSS
html5 svg 中元素点击事件添加方法
Jan 16 HTML / CSS
html5通过canvas实现刮刮卡效果示例分享
Jan 27 HTML / CSS
HTML5在线预览PDF的示例代码
Sep 14 HTML / CSS
Adobe Html5 Extension开发初体验图文教程
Nov 14 HTML / CSS
HTML5的postMessage的使用手册
Dec 19 HTML / CSS
关于HTML编码导致的乱码问题
Sep 04 HTML / CSS
html,css,javascript是怎样变成页面的
May 07 HTML / CSS
html5 sessionStorage会话存储_动力节点Java学院整理
Jul 06 #HTML / CSS
HTML5表格_动力节点Java学院整理
Jul 11 #HTML / CSS
html5嵌入内容_动力节点Java学院整理
Jul 07 #HTML / CSS
html5定制表单_动力节点Java学院整理
Jul 11 #HTML / CSS
html5文本内容_动力节点Java学院整理
Jul 11 #HTML / CSS
HTML5中视频音频的使用详解
Jul 07 #HTML / CSS
html5组织文档结构_动力节点Java学院整理
Jul 11 #HTML / CSS
You might like
PHP 截取字符串 分别适合GB2312和UTF8编码情况
2009/02/12 PHP
PHP获取中英混合字符串长度的方法
2014/06/07 PHP
PHP 面向对象程序设计(oop)学习笔记 (二) - 静态变量的属性和方法及延迟绑定
2014/06/12 PHP
php在线解压ZIP文件的方法
2014/12/30 PHP
phpmailer绑定邮箱的实现方法
2016/12/01 PHP
PHP基于redis计数器类定义与用法示例
2018/02/08 PHP
PHP基于DateTime类解决Unix时间戳与日期互转问题【针对1970年前及2038年后时间戳】
2018/06/13 PHP
PHP中数组转换为SimpleXML教程
2019/01/27 PHP
jquery $.ajax各个事件执行顺序
2010/10/15 Javascript
判断文件是否正在被使用的JS代码
2013/12/21 Javascript
javascript避免数字计算精度误差的方法详解
2014/03/05 Javascript
node.js应用后台守护进程管理器Forever安装和使用实例
2014/06/01 Javascript
jquery.mousewheel实现整屏翻屏效果
2015/08/30 Javascript
最简单的JavaScript图片轮播代码(两种方法)
2015/12/18 Javascript
javascript制作照片墙及制作过程中出现的问题
2016/04/04 Javascript
jQuery实现的placeholder效果完整实例
2016/08/02 Javascript
JS中位置与大小的获取方法
2016/11/22 Javascript
微信小程序 聊天室简单实现
2017/04/19 Javascript
微信小程序实现获取小程序码和二维码java接口开发
2019/03/29 Javascript
js实现多张图片每隔一秒切换一张图片
2019/07/29 Javascript
layui异步加载table表中某一列数据的例子
2019/09/16 Javascript
原生微信小程序开发中 redux 的使用详解
2021/02/18 Javascript
讲解Python中的递归函数
2015/04/27 Python
详解Python中pandas的安装操作说明(傻瓜版)
2019/04/08 Python
Python适配器模式代码实现解析
2019/08/02 Python
pytorch 常用线性函数详解
2020/01/15 Python
python 爬虫 实现增量去重和定时爬取实例
2020/02/28 Python
浅谈python3 构造函数和析构函数
2020/03/12 Python
详解如何在PyCharm控制台中输出彩色文字和背景
2020/08/17 Python
Python导入父文件夹中模块并读取当前文件夹内的资源
2020/11/19 Python
聊聊Python pandas 中loc函数的使用,及跟iloc的区别说明
2021/03/03 Python
现代家居用品及礼品:LBC Modern
2018/06/24 全球购物
2014年法院工作总结
2014/11/24 职场文书
幼儿园大班教师个人总结
2015/02/05 职场文书
先进个人总结范文
2015/02/15 职场文书
css position fixed 左右双定位的实现代码
2021/04/29 HTML / CSS