整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

HTML5新特性之localStorage与sess

HTML5新特性之localStorage与sessionStorage使用技巧

我们都知道localStorage与sessionStorage是用于本地存储的,那么我们该如何获取本地存储的大小呢?

如何监听storage事件,并作出后续处理呢?

今天这篇我们就一起来看看吧,文中的算法代码,已经放到了github上了,感兴趣的同学可以自取。

https://github.com/zhouxiongking/article-pages/tree/master/articles/H5Storage

HTML5

获取本地最大存储上限

localStorage与sessionStorage是一样的,我们就以localStorage为例进行代码编写。

主要思想:在localStorage中存储的信息都是{key: value}的字符串形式,所以只要我们通过setItem方法不停的加存储值的长度,直到抛出异常为止,我们就可以在catch中获取到本地存储的最大值。

通过以上的思想,我们可以得到以下的代码。

获取本地最大存储的方法

我们可以直接将上述代码复制到控制台的console栏下运行,就可以得到浏览器的本地最大存储的大小。

以下是在Chrome浏览器下的运行结果,从中可以看出Chrome浏览器的本地最大存储大小为5.12M。

Chrome浏览器下

以下是在Safari浏览器下的运行结果,从中可以看出Safari浏览器的本地存储大小为2.56M。

Safari浏览器下

从实际的运行结果可以看出不同的浏览器的本地存储localStorage大小是不同的。

如果想看看其他的浏览器的localStorage最大值,可以直接运行上述代码。

获取localStorage的剩余容量

有的时候我们在使用localStorage存放数据时,需要知道当前还剩余多少容量,该怎么办呢?

主要思想:我们同样用到localStorage中存放值是{key: value}字符串的原理。

  • 先通过上一节中的方法获取localStorage存储的最大值

  • 在for...in循环中,通过getItem方法获取所有已经使用的存储,然后累加起来

  • 最大值减去已经使用的存储空间,即可获取剩余的容量

通过以上的思想,我们可以得到以下的代码。

获取剩余容量

通过上述的代码我们就可以获取localStorage的剩余容量了。

storage事件

当localStorage或者sessionStorage中存储的值发生变化时,就会触发storage事件。

类似于click事件一样,localStorage与sessionStorage也可以触发storage事件,其定义的方式也是一样,可以通过addEventListener来实现。

但是需要注意的是:在默认情况下storage事件的触发是发生在同源下的不同页面中的。

上面这句话的意思是,如果我们在一个页面修改localStorage中存储的值,然后在同一个页面设置storage事件,这样是无效的。

当然我们可以修改默认的storage事件,改为自定义的方式,这个放在下节来讲。

为了印证上述的观点,我们使用两个页面,在页面A中通过localStorage给变量name设置初始值kingx,并且设置监听storage事件,然后在页面B中改变变量name的值为kingx2,最后来看看是否触发了页面A的storage事件。

页面A的代码如下。

页面A

页面B的代码如下。

页面B

当我们运行了页面A和页面B后,然后在页面B点击change按钮,修改name的值,然后回到页面A去查看console控制台,会发现有以下的结果。

测试结果

通过上述结果可以看出观点的正确性。

自定义storage事件

如果我们想要在当前页面监听修改localStorage值的事件,该如何实现呢?

可以通过自定义storage事件来实现。storage事件实际是在调用setItem时触发,因此我们只需要自定义setItem方法即可。

同一个页面下,在自定义的setItem方法中,自定义一个事件,然后使用window监听这个自定义事件。

得到的代码如下。

自定义storage事件

我们可以通过以下的代码来进行验证。

测试代码

运行的结果和上一节的结果是一样的。

结束语

本篇文章中主要介绍了与localStorage的几个算法,大家学会了吗?

essionStorage 是HTML5新增的一个会话存储对象,用于临时保存同一窗口(或标签页)的数据,在关闭窗口或标签页之后将会删除这些数据。本篇主要介绍 sessionStorage(会话存储)的使用方式。包括添加、修改、删除等操作。

说明:

sessionStorage 是HTML5新增的一个会话存储对象,用于临时保存同一窗口(或标签页)的数据,在关闭窗口或标签页之后将会删除这些数据。

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

适用场景:

sessionStorage 非常适合SPA(单页应用程序),可以方便在各业务模块进行传值。

其实:

html5中的Web Storage包括了两种存储方式:sessionStorage和localStorage。

sessionStorage:关闭页面就会销毁存储的数据

localStorage:用于持久化的本地存储,除非主动删除数据,否则数据是永远不会过期的。

-------下面我们来看看他有哪些属性和方法-------

属性:

readonly int sessionStorage.length //返回一个整数,表示存储在 sessionStorage 对象中的数据项(键值对)数量。

方法:

string sessionStorage.key(int index) //返回当前 sessionStorage 对象的第index序号的key名称。若没有返回null。

string sessionStorage.getItem(string key) //返回键名(key)对应的值(value)。若没有返回null。

void sessionStorage.setItem(string key, string value) //该方法接受一个键名(key)和值(value)作为参数,将键值对添加到存储中;如果键名存在,则更新其对应的值。

void sessionStorage.removeItem(string key) //将指定的键名(key)从 sessionStorage 对象中移除。

void sessionStorage.clear() //清除 sessionStorage 对象所有的项。

-------示例-------

存储数据

//采用setItem()方法存储

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

//通过属性方式存储

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

读取数据

//通过getItem()方法取值

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

//通过属性方式取值

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

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

var userEntity={

name: 'tom',

age: 22

};

// 存储值:将对象转换为Json字符串

sessionStorage.setItem('user', JSON.stringify(userEntity));

// 取值时:把获取到的Json字符串转换回对象

var userJsonStr=sessionStorage.getItem('user');

userEntity=JSON.parse(userJsonStr);

console.log(userEntity.name);

数组:

var arra=[1,2,3,4];

localStorage.setItem('key',JSON.stringify(arra));

var read=JSON.parse(localStorage.getItem('key'));

console.log(read,read.length);

注意: 

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

2) 单标签页限制。sessionStorage操作限制在单个标签页中,在此标签页进行同源页面访问都可以共享sessionStorage数据。

3) 只在本地存储。seesionStorage的数据不会跟随HTTP请求一起发送到服务器,只会在本地生效,并在关闭标签页后清除数据。(若使用Chrome的恢复标签页功能,seesionStorage的数据也会恢复)。

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

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

浏览器版本支持:

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


再来个小demo:

样式:

1 #container { 2 border: 2px solid gray; 3 width: 320px; 4 text-align:center; 5 }

html:

 1 <div id="container">
 2 <br>
 3 <label for="username">姓名:</label>
 4 <input type="text" id="username" name="username">
 5 <br>
 6 <label for="mobilephone">手机:</label>
 7 <input type="text" id="mobilephone" name="mobilephone">
 8 <br><br>
 9 <input type="button" onclick="add()" id="add" value="增加联系人">
10 <br><br>
11 <hr>
12 <label for="search">输入姓名:</label>
13 <input type="text" id="search" name="search">
14 <br><br>
15 <input type="button" onclick="find()" id="find" value="查找手机号">
16 <p id="result"><br></p>
17 </div>

js:

我们都知道localStorage与sessionStorage是用于本地存储的,那么我们该如何获取本地存储的大小呢?

如何监听storage事件,并作出后续处理呢?

今天这篇我们就一起来看看吧,文中的算法代码,已经放到了github上了,感兴趣的同学可以自取。

https://github.com/zhouxiongking/article-pages/tree/master/articles/H5Storage

HTML5

获取本地最大存储上限

localStorage与sessionStorage是一样的,我们就以localStorage为例进行代码编写。

主要思想:在localStorage中存储的信息都是{key: value}的字符串形式,所以只要我们通过setItem方法不停的加存储值的长度,直到抛出异常为止,我们就可以在catch中获取到本地存储的最大值。

通过以上的思想,我们可以得到以下的代码。

获取本地最大存储的方法

我们可以直接将上述代码复制到控制台的console栏下运行,就可以得到浏览器的本地最大存储的大小。

以下是在Chrome浏览器下的运行结果,从中可以看出Chrome浏览器的本地最大存储大小为5.12M。

Chrome浏览器下

以下是在Safari浏览器下的运行结果,从中可以看出Safari浏览器的本地存储大小为2.56M。

Safari浏览器下

从实际的运行结果可以看出不同的浏览器的本地存储localStorage大小是不同的。

如果想看看其他的浏览器的localStorage最大值,可以直接运行上述代码。

获取localStorage的剩余容量

有的时候我们在使用localStorage存放数据时,需要知道当前还剩余多少容量,该怎么办呢?

主要思想:我们同样用到localStorage中存放值是{key: value}字符串的原理。

  • 先通过上一节中的方法获取localStorage存储的最大值

  • 在for...in循环中,通过getItem方法获取所有已经使用的存储,然后累加起来

  • 最大值减去已经使用的存储空间,即可获取剩余的容量

通过以上的思想,我们可以得到以下的代码。

获取剩余容量

通过上述的代码我们就可以获取localStorage的剩余容量了。

storage事件

当localStorage或者sessionStorage中存储的值发生变化时,就会触发storage事件。

类似于click事件一样,localStorage与sessionStorage也可以触发storage事件,其定义的方式也是一样,可以通过addEventListener来实现。

但是需要注意的是:在默认情况下storage事件的触发是发生在同源下的不同页面中的。

上面这句话的意思是,如果我们在一个页面修改localStorage中存储的值,然后在同一个页面设置storage事件,这样是无效的。

当然我们可以修改默认的storage事件,改为自定义的方式,这个放在下节来讲。

为了印证上述的观点,我们使用两个页面,在页面A中通过localStorage给变量name设置初始值kingx,并且设置监听storage事件,然后在页面B中改变变量name的值为kingx2,最后来看看是否触发了页面A的storage事件。

页面A的代码如下。

页面A

页面B的代码如下。

页面B

当我们运行了页面A和页面B后,然后在页面B点击change按钮,修改name的值,然后回到页面A去查看console控制台,会发现有以下的结果。

测试结果

通过上述结果可以看出观点的正确性。

自定义storage事件

如果我们想要在当前页面监听修改localStorage值的事件,该如何实现呢?

可以通过自定义storage事件来实现。storage事件实际是在调用setItem时触发,因此我们只需要自定义setItem方法即可。

同一个页面下,在自定义的setItem方法中,自定义一个事件,然后使用window监听这个自定义事件。

得到的代码如下。

自定义storage事件

我们可以通过以下的代码来进行验证。

测试代码

运行的结果和上一节的结果是一样的。

结束语

本篇文章中主要介绍了与localStorage的几个算法,大家学会了吗?