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

使用关键技术:localStorage

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

1、JS代码

  1. // 获取window的localStorage对象
  2. var localS = window.localStorage;
  3. // 获取localStorage的值
  4. var getV = localS.getItem("value0"),
  5. getV2 = localS.getItem("value1");
  6. // 把获取到的值赋给对应的input
  7. $(".value0").val(getV);
  8. $(".value1").val(getV2);
  9. // 键盘按键弹起就设置localStorage的值
  10. $(document).on("keyup",function(){
  11. // 一个输入框对应一个value值
  12. var va = $(".value0").val(),
  13. va2 = $(".value1").val();
  14. // 有多少个就设置setItem多少个
  15. localS.setItem("value0",va);
  16. localS.setItem("value1",va2);
  17. });

2、效果图

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

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

1、JS代码

  1. // 所用到的变量统一写在一起
  2. var va,va2,getV,getV2;
  3. // 设置localStorage方法
  4. function localSet(){
  5. va = $(".value0").val(),
  6. va2 = $(".value1").val();
  7. localStorage.setItem("value0",va);
  8. localStorage.setItem("value1",va2);
  9. };
  10. // 获取localStorage方法
  11. function localGet(){
  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();

2、效果图

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

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

1、JS代码

  1. // 所用到的变量统一写在一起
  2. var va,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();

2、效果图

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

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

1、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();

2、效果图

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

第五步:使用json来存放localStorage

1、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 in json) {
  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();

2、效果图

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

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

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

  

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

Html5的localStorage与sessionStorage五种循序渐进的使用方法的更多相关文章

  1. HTML5的LocalStorage和sessionStorage的使用

    本文转载自:http://www.cnblogs.com/qiutianlidehanxing-blog/p/5953746.html html5中的Web Storage包括了两种存储方式:sess ...

  2. HTML5的localStorage和sessionStorage

    HTMl5提供了sessionStorage和localStorage数据存储方法,用于临时或者永久的存储客户端的数据: sessionStorage:用于保存回话数据 localStorage:用于 ...

  3. js的cookies及html5的localStorage、sessionStorage

    1.首先,理解什么是cookies? cookies:存储在客户端,数据量小的,会过期的数据,以字符串形式存储 cookie操作代码示例: <script> window.onload = ...

  4. 【Android 复习】:Android五种布局的使用方法

    ---恢复内容开始--- 在Android布局中,有五种常用的布局,下面我们就来学习一下这几种布局的使用方式 1) 线性布局:LinearLayout 2) 帧布局:  FrameLayout 3)  ...

  5. Html5之localStorage和sessionStorage缓存

    <!DOCTYPE html><html><head lang="en"> <meta charset="UTF-8" ...

  6. javascript中五种常见的DOM方法

    getElementById将返回一个与那个有着给定id属性值的元素节点对应的对象. <html xmlns="http://www.w3.org/1999/xhtml"&g ...

  7. Django REST framework 五种增删改查方法

    Django-DRF-视图的演变   版本一(基于类视图APIView类) views.py: APIView是继承的Django View视图的. 1 from .serializers impor ...

  8. Oracle--数据库中的五种约束

    数据库中的五种约束 数据库中的五种约束及其添加方法 五大约束 1.--主键约束(Primay Key Coustraint) 唯一性,非空性  2.--唯一约束 (Unique Counstraint ...

  9. IIS服务中五种身份验证

    转载:http://os.51cto.com/art/201005/202380.htm 作为微软最经典的Web服务之一的IIS服务有大致上五种Web身份认证方法.身份认证时保障IIS服务安全的根本, ...

随机推荐

  1. SDUT OJ 数据结构实验之二叉树二:遍历二叉树

    数据结构实验之二叉树二:遍历二叉树 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Problem Descr ...

  2. 网页footer背景(stick footer布局)

    今天遇到了一个有意思的问题,想在网站的foot里面加入一张背景图片,并且在footer的底部写下一些内容于是乎在footer添加了background,并设置了footer的大小 先说一下开始的做法: ...

  3. 4A - Horse

    打表找规律 #include <iostream> #include <queue> using namespace std; ][]; ]{, , , , -, -, -, ...

  4. python学习之路---day20--面向对象--多继承和super() 函数

    一:python多继承 python多继承中,当一个类继承了多个父类时候,这个类拥有多个父类的所欲非私有的属性 l例子: class A: pass class B(A): pass class C( ...

  5. ui-grid样式,表格高度自适应行高,没有滚动条,去掉表头

    前后端设置:

  6. QDU_组队训练(AJFC)

    A - Pretty Matrix DreamGrid's birthday is coming. As his best friend, BaoBao is going to prepare a g ...

  7. 字典树+map

    Problem Description Carryon最近喜欢上了一些奇奇怪怪的字符,字符都是英文小写字母,但奇怪的是a可能比b小,也可能比b大,好奇怪.与此同时,他拿到了好多的字符串,可是看着很不顺 ...

  8. Maven-常规问题

    1.编译(compile)Maven项目时,报错: -Dmaven.multiModuleProjectDirectory system property is not set. 处理方案:Windo ...

  9. git撤销commit,但未git push的命令

    在git push的时候,有时候我们会想办法撤销git commit的内容 1.找到之前提交的git commit的id git log 找到想要撤销的id 2.git reset –hard id ...

  10. oracle 笔记---(六)__表空间

    查看表空间的大小 select tablespace_name,block_size,contents from dba_tablespaces; 查看表空间对应的数据文件 select file_n ...