js操作cookie保存一些基本信息

释放双眼,带上耳机,听听看~!

JS设置cookie:

假设在A页面中要保存变量username的值(“Tokin”)到cookie中,key值为name,则相应的JS代码为:
document.cookie="name="+username;
JS读取cookie:

假设cookie中存储的内容为:name=Tokin;xxx=xxx;…

则在B页面中获取变量username的值的JS代码如下:
var username=document.cookie.split(";")[0].split("=")[1];
最后,username就可以取出来了。

既然知道了基本的cookie读写操作,那我们可以把这个操作封装成一系列函数,方便之后的频繁调用。

函数如下

//写cookies
function setCookie(name,value)
{
   var Days = 30;
   var exp = new Date();
   exp.setTime(exp.getTime() + Days*24*60*60*1000);
   document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
   var strsec = getsec(time);
   var exp = new Date();
   exp.setTime(exp.getTime() + strsec*1);
   document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}

//读cookies
function getCookie(name)
{
   var arr,reg=new RegExp("(^| )"+name+"=([^;]*)(;|$)");
   if(arr=document.cookie.match(reg)) return (arr[2]);
   else return null;
}

//删cookies
function delCookie(name)
{
   var exp = new Date();
   exp.setTime(exp.getTime() - 1);
   var cval=getCookie(name);
   if(cval!=null) document.cookie= name + "="+cval+";expires="+exp.toGMTString();
}

使用示例

setCookie("name","Tokin"); //写cookie
console.log(getCookie("name")); //读cookie
delCookie("name"); //删cookie
console.log(getCookie("name")); //再次读应该是读不到的

拓展功能

如果需要设定自定义过期时间,那么把上面的setCookie 函数换成下面两个函数就ok

//写cookie
function setCookie(name,value,time)
{
   var strsec = getsec(time);
   var exp = new Date();
   exp.setTime(exp.getTime() + strsec*1);
   document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}

//设置时间
function getsec(str)
{
  alert(str);
  var str1=str.substring(1,str.length)*1;//获取字母后的数字(这一步也可以过滤字母就获取到数字了)
  var str2=str.substring(0,1);//获取字符串字一个字母
  if (str2=="s") return str1*1000;
  else if (str2=="h") return str1*60*60*1000;
  else if (str2=="d") return str1*24*60*60*1000;
}
//这是有设定过期时间的使用示例:
//s30是代表30秒
//h是指小时,如12小时则是:h12
//d是天数,30天则:d30

setCookie("name","Tokin","h12"); //写入操作,可以设定过期时间了(12小时)

基本的代码就像上面,发挥自己的想象力吧

给TA买糖
共{{data.count}}人
人已赞赏
知识分享

通过Dnsmasq自建干净的DNS服务

2020-8-21 10:16:00

知识分享

解决 mariadb/mysql 在低配 VPS 上崩溃问题

2020-8-21 10:20:00

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索