言
我们都知道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的几个算法,大家学会了吗?
*请认真填写需求信息,我们会在24小时内与您取得联系。