设计笔记

  • 函数如下
  • 使用示例
  • 拓展功能
  • 首页
  • 作品
  • 代码
  • 随笔
  • 关于博主
    • 豆瓣书影
  • 友情链接
  • 文章归档
  • 榜上有名
  • RSS Feed
  • GitHub
  • Twitter
  • Link

喜欢这款主题

抢先体验

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

  • Tokin
  • 2017-01-12
  • 20

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

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

© 2025 设计笔记
Theme by Wing
  • {{ item.name }}
  • {{ item.name }}