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 小时)

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

© 版权声明
THE END
打赏一根烟,继续保持。
点赞0打赏作者 分享
评论 共2条
头像
友好交流,请勿发纯表情,请勿灌水,违者封号喔
提交
头像

昵称

取消
昵称表情代码图片
    • 头像龙笑天0