最近做了记住密码功能,用localStorage跟cookie都尝试用了一下,感觉都挺好哈,很方便,特此记录

html代码:

<input type="text" id="userName" placeholder="账号">
<input type="password" id="password" placeholder="密码"/>
<input class="remember" type="checkbox" style="width: 0.3rem;margin-top: 0px;" id="" value=""/><label style="line-height: 32px;">记住密码</label>
<button id="btn">登录</button>

Js代码:

<script type="text/javascript">
 //点击记住密码按钮
$(".remember").click(function(){ //如果有值,则将用户名跟密码存入localStorage或者cookie
  if($(this).prop('checked') && $("#password").val()&& $("#userName").val()){
    //localStorage.setItem("password",$("#password").val()); //存入localStorage写法
    //localStorage.setItem("userName",$("#userName").val());
    $.cookie('password', $("#password").val(), { expires: 7 }); //存入cookie写法(expires:7表示设置有效期为7天)
    $.cookie('userName', $("#userName").val(), { expires: 7 });
  }else{
    //localStorage.setItem("password",'');
    //localStorage.setItem("userName",'');
    $.cookie("password",'',{ expires: -1 });
    $.cookie("userName",'',{ expires: -1 });
  } })
$("#btn").click(function(){
  if($(".remember").prop('checked') && $("#password").val()&& $("#userName").val()){
    //localStorage.setItem("password",$("#password").val());
    //localStorage.setItem("userName",$("#userName").val());
    // 创建一个cookie并设置有效时间为7天:
    $.cookie('password', $("#password").val(), { expires: 7 });
    $.cookie('userName', $("#userName").val(), { expires: 7 });
    console.log($.cookie('password'));
  }else{
    $.cookie('password', '',{ expires: -1 }); //清空cookie里的password
    $.cookie('userName', '',{ expires: -1 }); //清空cookie里的userName
    //localStorage.setItem("password",''); //清空localStorage里的password
    //localStorage.setItem("userName",''); //清空localStorage里的userName
  }
    var userName = $("#userName").val();
    var password = $("#password").val();
    if(!userName){
      alertTip("请输入账号!");
    }
    if(!password){
 alertTip("请输入密码!");
    }
    $.ajax({
      url : basePath + '/login?loginName=' + userName + '&password=' + encodeURIComponent(password),
      dataType : 'json',
      type : "post",
 success : function(data) {
   if (!data.success) {
alertTip(data.errmsg);
return;
   }
   var userUid=data.user.userUid;
   toApp(userUid)
        window.location.href = 'index.html';
      },
      error : function() {
        alertTip("未能连接到服务器!");
      }
    });
})
  function toApp(userUid){
    if (isAndroid()) { //给androidapp传参数
      var jsonStr = JSON.stringify({"userUid": userUid});
      AppHost.getUserUid(jsonStr);
    } else { //给ios传参数
      window.webkit.messageHandlers.getUserUid.postMessage({"userUid": userUid});
    }
  }
</script>

两者区别:

1.cookie的存储大小为4KB,而localStorage的存储数据大小一般都是:5MB

2.cookie若不设置有效时间,则生命周期随浏览器的关闭而结束,若设置了有效时间,则浏览器关闭,cookie数据也在,知道过了有效时间;而localStorage数据,除非你手动清楚,否则会一直存在

localStorage跟cookie的使用的更多相关文章

  1. sessionStorage 、localStorage 与cookie 的异同点

    cookie 容量4kb,默认各种浏览器都支持,缺陷就是每次请求,浏览器都会把本机存的cookies发送到服务器,无形中浪费带宽.userdata,只有ie支持,单个容量64kb,每个域名最多可存10 ...

  2. sessionStorage 、localStorage 和 cookie 之间的区别

    sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可以方便的在web请求之间保存数据.有了本地数据,就可以避免数据在浏览器和服务器间不必 ...

  3. sessionStorage 、localStorage 和 cookie 之间的区别(转)

    essionStorage .localStorage 和 cookie 之间的区别(转) 2012-05-08 14:29:19|  分类: HTML5CSS3WEBAPP|举报|字号 订阅     ...

  4. 本地存储sessionStorage 、 localStorage 、cookie整理

    sessionStorage . localStorage .cookie 的区别 sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可 ...

  5. sessionStorage、localStorage、cookie

    sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可以方便的在web请求之间保存数据.有了本地数据,就可以避免数据在浏览器和服务器间不必 ...

  6. sessionstorage,localstorage和cookie之间的区别以及各自的用法

    由于年前辞了自己的工作,年后又开始重新找工作,参加了好几次面试,居然都遇到了同样的面试题:sessionstorage,localstorage和cookie之间的是区别? 当然,在面试的时候答的也不 ...

  7. sessionStorage 、localStorage 和 cookie

    localStorage 和 sessionStorage HTML5 提供了两种在客户端存储数据的新方法:localStorage 和 sessionStorage: 两者都是仅在客户端(即浏览器) ...

  8. localStorage sessionStorage cookie indexedDB

    目录: localStorage sessionStorage cookie indexedDB localStorage localStorage存储的数据能在跨浏览器会话保留 数据可以长期保留,关 ...

  9. localStorage和cookie操作

    localStorage和cookie操作代码: cookie: { isSupportCookie: function() { return navigator.cookieEnabled; }, ...

随机推荐

  1. 数学规划求解器lp_solve超详细教程

    前言 最近小编学了运筹学中的单纯形法.于是,很快便按奈不住跳动的心.这不得不让我拿起纸和笔思考着,一个至关重要的问题:如何用单纯形法装一个完备的13? 恰巧,在我坐在图书馆陷入沉思的时候,一位漂亮的小 ...

  2. 实现函数 ToLowerCase()

    /** * 实现函数 ToLowerCase(),该函数接收一个字符串参数 str, 并将该字符串中的大写字母转换成小写字母,之后返回新的字符串. * 输入: "Hello" * ...

  3. rbac表设计

  4. curl 命令大全

    post json curl -H "Content-Type: application/json" -X POST --data '{"userID":100 ...

  5. hibernate核心开发接口_Configuration

    AnnotationConfiguration继承自Configuration,这里以AnnotationConfiguration为例: new AnnotationConfiguration(). ...

  6. 比特 字节 兆 GB转换

    bit:比特byte:拜特(字节) 1字节=8比特k:千KB:千字节 1KB = 1024 byteMB:兆字节GB:千兆字节 //少用 Kb:千比特 Mb:兆比特 Gb:千兆比特

  7. JS写游戏

    最近在看萧井陌的视频.感觉一些东西挺有意思的,尤其是解决问题的过程,以及一个好程序应该改进的地方. 萧大的GITHUB:github.com/guaxiao/gua.game.js 视频:https: ...

  8. ubuntu关闭时间同步与centos更改时间

    环境:ubuntu 源于一次项目需要修改系统时间,但是每次修改后又被同步回网络时间,找了好久发现是这个原因: NTP即Network Time Protocol(网络时间协议),是一个互联网协议,用于 ...

  9. C#(winform)的label自动换行

    Label 是没有自动换行属性的,不像Textbox有WordWrap属性 尽管没有自动换行的属性,但也能够自动换行, 首先 AutoSize改成false; 然后调整 Label的大小,长和宽 (也 ...

  10. msyql int(x) 中的x

    先看一个mysql表结构 Sql代码 CREATE   TABLE  `test` ( `TYPEID` int (2) ) ENGINE=MyISAM CHARSET=latin1; Sql代码   ...