当前位置:首页 > 日记 > 正文

JS中LocalStorage与SessionStorage五种循序渐进的使用方法

JS中LocalStorage与SessionStorage五种循序渐进的使用方法

localStorage和sessionStorage一样都是用来存储客户端临时信息的对象。

他们均只能存储字符串类型的对象(虽然规范中可以存储其他原生类型的对象,但是目前为止没有浏览器对其进行实现)。

localStorage生命周期是永久,这意味着除非用户显示在浏览器提供的UI上清除localStorage信息,否则这些信息将永远存在。

sessionStorage生命周期为当前窗口或标签页,一旦窗口或标签页被永久关闭了,那么所有通过sessionStorage存储的数据也就被清空了。

不同浏览器无法共享localStorage或sessionStorage中的信息。相同浏览器的不同页面间可以共享相同的localStorage(页面属于相同域名和端口),但是不同页面或标签页间无法共享sessionStorage的信息。这里需要注意的是,页面及标签页仅指顶级窗口,如果一个标签页包含多个iframe标签且他们属于同源页面,那么他们之间是可以共享sessionStorage的。

需求:本地记录用户上次输入的内容

使用关键技术:localStorage

第一步:使用jQuery的普通写法

1、JS代码

// 获取window的localStorage对象var localS = window.localStorage;// 获取localStorage的值var getV = localS.getItem("value0"), getV2 = localS.getItem("value1");// 把获取到的值赋给对应的input$(".value0").val(getV);$(".value1").val(getV2);// 键盘按键弹起就设置localStorage的值$(document).on("keyup",function(){ // 一个输入框对应一个value值 var va = $(".value0").val(),  va2 = $(".value1").val(); // 有多少个就设置setItem多少个 localS.setItem("value0",va); localS.setItem("value1",va2);});

2、效果图

3、额额...可以用,不过,问题来了,这JS代码写的...有点乱啊,后期不好维护啊有木有!怎么办??有什么办法可以解决??

第二步:使用JS函数方法来写

1、JS代码

// 所用到的变量统一写在一起var va,va2,getV,getV2;// 设置localStorage方法function localSet(){ va = $(".value0").val(), va2 = $(".value1").val(); localStorage.setItem("value0",va); localStorage.setItem("value1",va2);};// 获取localStorage方法function localGet(){ getV = localStorage.getItem("value0"), getV2 = localStorage.getItem("value1"); $(".value0").val(getV); $(".value1").val(getV2);}// 键盘按键弹起就设置localStorage的值$(document).on('keyup',function(){ localSet();});// 页面一加载就调用设置localStorage的方法localGet();

2、效果图

3、嗯嗯...改为函数就很容易知道哪个是设置哪个是获取localStorage了,还可以。不过,问题来了,我不想用函数,我要用面向对象写法,怎么办??

第三步:JS面向对象的写法

1、JS代码

// 所用到的变量统一写在一起var va,va2,getV,getV2;var localObj = { // 设置localStorage方法 localSet : function(){  va = $(".value0").val(),  va2 = $(".value1").val();  localStorage.setItem("value0",va);  localStorage.setItem("value1",va2); }, // 获取localStorage方法 localGet : function(){  getV = localStorage.getItem("value0"),  getV2 = localStorage.getItem("value1");  $(".value0").val(getV);  $(".value1").val(getV2); }}$(document).on('keyup',function(){ localObj.localSet();});// 页面一加载就调用设置localStorage的方法localObj.localGet();

2、效果图

3、哈哈...改了一下就好了,还蛮简单的嘛!不过,问题来了,如果有很多个input框需要记录,那岂不是得写很多代码?能不能循环处理一下??

第四步:使用for循环的写法

1、JS代码

var localObj = { // 设置localStorage方法 localSet : function(){  // 我这里测试用的,所以直接选中所有的input长度,实际使用换成相同类名即可  for (var i = 0; i < $("input").length; i++) {   // 这里要注意,所有的localStorage的key都要相同,只是数字不同而已   localStorage.setItem("value"+i,$(".value"+i).val());  } }, // 获取localStorage方法 localGet : function(){  for (var i = 0; i < $("input").length; i++) {   // 获取对应的key值,因为这里使用的是value+数字,所以直接这样获取即可   $(".value"+i).val(localStorage.getItem("value"+i));  } }}$(document).on('keyup',function(){ localObj.localSet();});localObj.localGet();

2、效果图

3、呦呦...想加多少个,就加多少个value,还不错呦,代码又比较简洁。不过,问题又来了。我不想一直使用类名value+数字,我已经有写好了的类名了,我想用什么名字就用什么名字,而且不想弄一大堆localStorage,难道有100个input,就要我弄100个localStorage??我就想弄一个localStorage记录就好。怎么办??

第五步:使用json来存放localStorage

1、JS代码

var localObj = { localSet: function(){  // 定一个对象,来存放键值对  var arr = {};   // 有多少个值,就对应写多少个,名字可随便命名   arr.value0 = $(".value0").val();   arr.value1 = $(".value1").val();   arr.od = $(".od").val();   arr. = $(".").val();  // 将arr对象转换为string类型  var his = JSON.stringify(arr);  // 设置一个localStorage名字叫histroy,值为his  localStorage.setItem("histroy",his); }, localGet: function(){  // 获取一个叫histroy的localStorage,存放在arr变量中  var arr = localStorage.getItem("histroy");  // 把获取来的arr转换成json格式  var json = JSON.parse(arr);  // 遍历Json中的数据  for (var li in json) {   // 由json字符串转换为json对象   var value = eval("json['" + li +"']");   // 把取到的对应的value值赋值给对应的li   arr.li = value;   // 最后一步,显示对应的value值   $("."+li).val(value);  } }}// 键盘按键弹起的时候改变localStorage的值$(document).on('keyup',function(){ localObj.localSet();});// 浏览器一打开就显示存储在localStorage里面的值// 即记录上次输入的值localObj.localGet();

2、效果图

3、哇~,不错不错,到第五步,基本就已经解决了我们的需求了,不过(TMD还有问题?)哈哈哈哈。。。

  1)假设不单单是input要记录上次输入内容,复选框CheckBox也要记录是否上次被选中的问题,怎么解决??

  2) 百度翻译使用的是多个数组来存放多个内容,怎么弄??

 

最后:如果使用sessionStorage,直接把localStorage替换成sessionStorage就好了,其它的一模一样!!!

以上所述是小编给大家介绍的JS中LocalStorage与SessionStorage五种循序渐进的使用方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

相关文章

浅谈php中的访问修饰符private、pr

浅谈php中的访问修饰符private、pr

作用,访问修饰符,浅谈,电脑软件,php,1、 private 只能在类内部使用2、 protected 可以在类内部和继承类里使用。类外部不能使用【即实例化后的对象无法调用】3、 public 全部范围适用。4、子类复写父类中的方法时,子类中的 访问修饰符的范围…

ES6中字符串string常用的新增方法

ES6中字符串string常用的新增方法

方法,字符串,常用,电脑软件,string,本文实例讲述了ES6中字符串string常用的新增方法。分享给大家供大家参考,具体如下:ES6为js新增了很多方法,包括遍历、查询、替换等等,可以很简洁的替换ES5中的类似方法,本文不考虑codePointAt等不常用方法。fo…

thinkPHP中_initialize方法实例分

thinkPHP中_initialize方法实例分

实例分析,方法,电脑软件,thinkPHP,_initialize,本文实例讲述了thinkPHP中_initialize方法。分享给大家供大家参考,具体如下:子类的_initialize方法自动调用父类的_initialize方法。而php的构造函数construct,如果要调用父类的方法,必须在子类构…

win8如何彻底关闭uac

win8如何彻底关闭uac

电脑软件,uac,从Windows Vista以来,UAC的安全性控制就是使用者心中的痛,不仅造成操作上的不方便,对于真正的病毒威胁也没有足够的防御效果,因此很多读者都会选择将UAC关闭,不过这次Win 8可不一样喔!照以前的方法竟然无法完全关闭UAC,我们当然要出…

利用JavaScript如何查询某个值是否

利用JavaScript如何查询某个值是否

数组,查询,电脑软件,JavaScript,本文主要给大家介绍了关于利用JavaScript查询某个值是否数组内的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍:问题> var b = ["aa", "bb"]> "aa" in b我要查询字符串aa是否在数…

老生常谈PHP数组函数array_merge |

老生常谈PHP数组函数array_merge |

函数,数组函数,老生常谈,必看,电脑软件,很久之前就用到过这个函数,只不不过是简单的用用而已并没有做太深入的研究今天在翻阅别人博客时看到了对array_merge的一些使用心得,故此自己来进行一次总结。 array_merge是将一个或者多个数组进行合…

PHP中利用sleep函数实现定时执行功

PHP中利用sleep函数实现定时执行功

功能实现,函数实现,定时执行,代码,电脑软件,在一些竞猜的网站中,如果我们需要做一个定时执行的功能,比如有一道题,在十秒之内要完成,否则显示“您已超时”,如果完成,则跳转到下一道题上面,而这中间有一个十秒的停顿,这样的功能是怎样实现的呢?在PHP…

Laravel中encrypt和decrypt的实现

Laravel中encrypt和decrypt的实现

方法,电脑软件,Laravel,encrypt,decrypt,前言Laravel 的加密机制使用 OpenSSL 提供 AES-256 和 AES-128 的加密,本文将详细介绍关于Laravel中encrypt和decrypt的实现,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。1. 使用方…

nodejs判断文件、文件夹是否存在及

nodejs判断文件、文件夹是否存在及

删除,方法,文件,是否存在,电脑软件,本文实例讲述了nodejs判断文件、文件夹是否存在及删除的方法。分享给大家供大家参考,具体如下:判断文件、文件夹是否存在需要使用nodejs的fs模块引入var fs= require("fs")判断的方法fs.exists(path, cal…

使用Node.js实现ORM的一种思路详解

使用Node.js实现ORM的一种思路详解

详解,思路,图文,电脑软件,Node,ORM是O和R的映射。O代表面向对象,R代表关系型数据库。二者有相似之处同时也各有特色。就是因为这种即是又非的情况,才需要做映射的。理想情况是,根据关系型数据库(含业务需求)的特点来设计数据库。同时根据面向对…

painter怎么绘制丛林树枝外观效果

painter怎么绘制丛林树枝外观效果

图形,绘制,树枝,丛林,外观,Painter中想要绘制一个松树枝,该怎么制作呢?下面我们就来看看使用painter绘制的方法。软件名称:Corel Painter(绘画软件) 2018 官方正式版(附注册机) 在线安装包 64位软件大小:994KB更新时间:2017-06-301、打开Painter…

Photoshop制作丛林蟒蛇缠绕啤酒魔

Photoshop制作丛林蟒蛇缠绕啤酒魔

蟒蛇,丛林,海报,风格,电脑软件,有一些小伙伴问我这个是怎么做出来的,所以发出来分享一下!我自己也还在学习当中,有些不好的地方请大家多多提点。最终效果 寻找一些素材。一、搭建场景。二、调色与混合模式。 三、酒瓶的调整。12 3 阅读全文四…