html session 使用方法,Html5的localStorage与sessionStorage五种按部就班的使用方法

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

使用关键技术:localStorage数组

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

一、JS代码session

//获取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);

});

二、效果图函数

97b27f2b8610fc688035649cebf8413b.png

三、额额...能够用,不过,问题来了,这JS代码写的...有点乱啊,后期很差维护啊有木有!怎么办??有什么办法能够解决??测试

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

一、JS代码翻译

1 //所用到的变量统一写在一块儿

2 varva,va2,getV,getV2;3 //设置localStorage方法

4 functionlocalSet(){5 va = $(".value0").val(),6 va2 = $(".value1").val();7 localStorage.setItem("value0",va);8 localStorage.setItem("value1",va2);9 };10 //获取localStorage方法

11 functionlocalGet(){12 getV = localStorage.getItem("value0"),13 getV2 = localStorage.getItem("value1");14 $(".value0").val(getV);15 $(".value1").val(getV2);16 }17 //键盘按键弹起就设置localStorage的值

18 $(document).on('keyup',function(){19 localSet();20 });21 //页面一加载就调用设置localStorage的方法

22 localGet();

二、效果图3d

3ded89244cd59fdc198e4c63d1d88838.png

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

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

一、JS代码

1 //所用到的变量统一写在一块儿

2 varva,va2,getV,getV2;3 var localObj ={4 //设置localStorage方法

5 localSet : function(){6 va = $(".value0").val(),7 va2 = $(".value1").val();8 localStorage.setItem("value0",va);9 localStorage.setItem("value1",va2);10 },11 //获取localStorage方法

12 localGet : function(){13 getV = localStorage.getItem("value0"),14 getV2 = localStorage.getItem("value1");15 $(".value0").val(getV);16 $(".value1").val(getV2);17 }18 }19 $(document).on('keyup',function(){20 localObj.localSet();21 });22 //页面一加载就调用设置localStorage的方法

23 localObj.localGet();

二、效果图

7a9c4377e0f8bbf37b6c875d428ae440.png

三、哈哈...改了一下就行了,还蛮简单的嘛!不过,问题来了,若是有不少个input框须要记录,那岂不是得写不少代码?能不能循环处理一下??

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

一、JS代码

1 var localObj ={2 //设置localStorage方法

3 localSet : function(){4 //我这里测试用的,因此直接选中全部的input长度,实际使用换成相同类名便可

5 for (var i = 0; i < $("input").length; i++) {6 //这里要注意,全部的localStorage的key都要相同,只是数字不一样而已

7 localStorage.setItem("value"+i,$(".value"+i).val());8 }9 },10 //获取localStorage方法

11 localGet : function(){12 for (var i = 0; i < $("input").length; i++) {13 //获取对应的key值,由于这里使用的是value+数字,因此直接这样获取便可

14 $(".value"+i).val(localStorage.getItem("value"+i));15 }16 }17 }18 $(document).on('keyup',function(){19 localObj.localSet();20 });21 localObj.localGet();

二、效果图

16e7283484aedcee1585bc953956215c.png

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

第五步:使用json来存放localStorage

一、JS代码

1 var localObj ={2 localSet: function(){3 //定一个对象,来存放键值对

4 var arr ={};5 //有多少个值,就对应写多少个,名字可随便命名

6 arr.value0 = $(".value0").val();7 arr.value1 = $(".value1").val();8 arr.good = $(".good").val();9 arr.go = $(".go").val();10 //将arr对象转换为string类型

11 var his =JSON.stringify(arr);12 //设置一个localStorage名字叫histroy,值为his

13 localStorage.setItem("histroy",his);14 },15 localGet: function(){16 //获取一个叫histroy的localStorage,存放在arr变量中

17 var arr = localStorage.getItem("histroy");18 //把获取来的arr转换成json格式

19 var json =JSON.parse(arr);20 //遍历Json中的数据

21 for (var li injson) {22 //由json字符串转换为json对象

23 var value = eval("json['" + li +"']");24 //把取到的对应的value值赋值给对应的li

25 arr.li =value;26 //最后一步,显示对应的value值

27 $("."+li).val(value);28 }29 }30 }31 //键盘按键弹起的时候改变localStorage的值

32 $(document).on('keyup',function(){33 localObj.localSet();34 });35 //浏览器一打开就显示存储在localStorage里面的值

36 //即记录上次输入的值

37 localObj.localGet();

二、效果图

368536f2ffd0c6035ada98c112768ff0.png

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

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

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

40381b6bf7ccd2fd78ed3263e5ed08ce.png

最后:若是使用sessionStorage,直接把localStorage替换成sessionStorage就行了,其它的如出一辙!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值