localStorage跟cookie的使用
最近做了记住密码功能,用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的使用的更多相关文章
- sessionStorage 、localStorage 与cookie 的异同点
cookie 容量4kb,默认各种浏览器都支持,缺陷就是每次请求,浏览器都会把本机存的cookies发送到服务器,无形中浪费带宽.userdata,只有ie支持,单个容量64kb,每个域名最多可存10 ...
- sessionStorage 、localStorage 和 cookie 之间的区别
sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可以方便的在web请求之间保存数据.有了本地数据,就可以避免数据在浏览器和服务器间不必 ...
- sessionStorage 、localStorage 和 cookie 之间的区别(转)
essionStorage .localStorage 和 cookie 之间的区别(转) 2012-05-08 14:29:19| 分类: HTML5CSS3WEBAPP|举报|字号 订阅 ...
- 本地存储sessionStorage 、 localStorage 、cookie整理
sessionStorage . localStorage .cookie 的区别 sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可 ...
- sessionStorage、localStorage、cookie
sessionStorage 和 localStorage 是HTML5 Web Storage API 提供的,可以方便的在web请求之间保存数据.有了本地数据,就可以避免数据在浏览器和服务器间不必 ...
- sessionstorage,localstorage和cookie之间的区别以及各自的用法
由于年前辞了自己的工作,年后又开始重新找工作,参加了好几次面试,居然都遇到了同样的面试题:sessionstorage,localstorage和cookie之间的是区别? 当然,在面试的时候答的也不 ...
- sessionStorage 、localStorage 和 cookie
localStorage 和 sessionStorage HTML5 提供了两种在客户端存储数据的新方法:localStorage 和 sessionStorage: 两者都是仅在客户端(即浏览器) ...
- localStorage sessionStorage cookie indexedDB
目录: localStorage sessionStorage cookie indexedDB localStorage localStorage存储的数据能在跨浏览器会话保留 数据可以长期保留,关 ...
- localStorage和cookie操作
localStorage和cookie操作代码: cookie: { isSupportCookie: function() { return navigator.cookieEnabled; }, ...
随机推荐
- docker微服务部署之:一,搭建Eureka微服务项目
先说明一下docker需要搭建的微服务的基本情况: 项目情况:一个demo_parent项目,下面三个子模块:demo_eureka(eureka服务).demo_article(文章服务).demo ...
- Carte作为Windows服务
有一些用例将Carte作为Windows服务运行: 当使用命令窗口运行Carte实例时,任何人都会错误地关闭实例并且Carte将关闭. Carte.bat命令窗口与调用批处理文件的用户会话相关联,需要 ...
- MySQL数据库的账户管理
账户管理 在生产环境下操作数据库时,绝对不可以使用root账户连接,而是创建特定的账户,授予这个账户特定的操作权限,然后连接进行操作,主要的操作就是数据的crud MySQL账户体系:根据账户所具有的 ...
- 判断h5页面是小程序环境还是微信环境
1.话不多说直接上代码,已使用有效 <script type="text/javascript" src="https://res.wx.qq.com/open/j ...
- ASP.NET MVC 下拉列表实现
https://blog.csdn.net/Ryan_laojiang/article/details/75349555?locationNum=10&fps=1 前言 我们今天开始好好讲讲关 ...
- 【CF1157F】Maximum Balanced Circle 求一个相邻元素之间绝对值为小于1的最大环
题目: https://codeforces.com/contest/1157/problem/F 给出一个序列 , 我们要从序列里面挑出一些数构造成一个相邻元素之间绝对值为小于1的最大环 , 挑选的 ...
- JavaSwing程序设计(目录)
一.JavaSwing 概述 JavaSwing 图形界面概述 二.JavaSwing 基本组件 JLabel(标签) JButton(按钮) JTextField(文本框) JPasswordFie ...
- C#二进制位算 权限
关于权限管理,之前所做的都是一个权限对应一条数据,比方A页面有增删改查四个权限,那么用户在权限管理表中相对应AA页面有四条记录.后来改用二进制运算,发现省事很多. 首先说下位运算 熟悉一下操作符,懒得 ...
- Mac下在Shell终端下使用open快速打开窗口文件夹
Ubuntu下可以使用nautilus打开,但是在Mac替代的是open. 打开当前路径的窗口 oepn . 打开其他窗口 open /dirname 其实open不只可以打开窗口,应用同样支持. 关 ...
- Android:刚6瓶啤酒4两56度白酒下肚,居然20分钟做了一手机版网站 !
刚6瓶啤酒4两56度白酒下肚,居然20分钟不到时间做了一手机版网站 !人有多大潜力你知道吗? 大家有兴趣的可以用手机或微信打开 http://xh.yunxunmi.com/ 看看俺这酒后之做! 更 ...