javscript对cookie的操作,以及封装

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Document</title>
</head>
<body>
  用户名:<input type="text" name="user" id="user">
  年龄:<input type="text" name="age" id="age">
  <input type="button" name="" value="提交" id="btn">
</body>
</html>

  

JS代码

<script type="text/javascript">
  // 设置cookie
  function setCookie(){
    // 获取当前时间
    var date = new Date();
    
    // 支持传一个json {name:value}
    var a = arguments;
    if(a.length==2){
      // 设置过期时间 = 当前时间 + 过期时间;
      date.setDate(date.getDate()+a[1]);
      for(k in a[0]){
        document.cookie = k +"="+ encodeURI(a[0][k]) +";expires=" + date.toGMTString()+";path=/";
      }
    }else{
      date.setDate(date.getDate()+a[2]);
      // 设置cookie = 值=value  encodeURI(把值进行编码) expires设置过期时间 path设置网站目录访问cookie权限,/表示当前域名下的所有目录都可以访问这个cookie
      document.cookie = a[0] +"="+ encodeURI(a[1]) +";expires=" + date.toGMTString()+";path=/";
    }
  }
  // 读取cookie
  function readCookie(name){
    // 获取cookie decodeURI把cookie进行解码
    var cookie = decodeURI(document.cookie);
    // 获取当前名称的起始索引
    var start = cookie.indexOf(name+'=');
    // 如果找不到这个名称的话就直接返回;
    if(start==-1)return '';
    // 获取结束索引,start表示开始查找的起点
    var end = cookie.indexOf(';',start);
    // 如果返回-1说明是最后一条数据
    if(end==-1){
      // 最后一条直接截取到末尾
      return cookie.substring(start+name.length+1);
    }
    // 如果不是末尾的话截取到;
    return cookie.substring(start+name.length+1,end);
  }
  // 删除cookie
  function removeCookie(name){
    document.cookie = name + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT;path=/";
  }

  // 写入cookie
  var oBtn = document.getElementById('btn');
  oBtn.onclick = function(){
    var user = document.getElementById('user').value;
    var age = document.getElementById('age').value;
    // 设置cookie
    setCookie({
      'user':user,
      'age':age
    },10);
  };

  // 打印cookie
  console.log(readCookie('user'));
</script>

  

使用方法:

  设置cookie:setCookie()支持传递2个或3个参数 json&&time || nam&&value&&time              json:{name:value},time:多久过期

  读取cookie:readCookie(要读取的cookie名称)

  删除cookie:removeCookie(要删除的cookie名称)

  

以上也是闲来无事写的,仅供参考,如果有不懂的可以在下方留言,如果多人需要帮助的话我再另外开一片文章专门讲。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当涉及到读写 Cookie 时,可以使用以下方法进行封装: 1. 设置 Cookie:使用`document.cookie`属性来设置 Cookie。通过传递参数来设置 Cookie 的名称、值以及其他可选的属性(例如过期时间、路径等)。封装一个函数如下: ```javascript function setCookie(name, value, days, path) { let expires = ""; if (days) { let date = new Date(); date.setTime(date.getTime() + (days * 24 * 60 * 60 * 1000)); expires = "; expires=" + date.toUTCString(); } document.cookie = name + "=" + (value || "") + expires + "; path=" + (path || "/"); } ``` 使用示例: ```javascript setCookie("username", "John Doe", 7); // 设置一个名为 "username" 的 Cookie,有效期为7天 ``` 2. 获取 Cookie:使用`document.cookie`属性来获取所有的 Cookie,然后解析出指定名称的 Cookie 值。封装一个函数如下: ```javascript function getCookie(name) { let cookieArr = document.cookie.split("; "); for (let i = 0; i < cookieArr.length; i++) { let cookiePair = cookieArr[i].split("="); if (name === cookiePair[0]) { return decodeURIComponent(cookiePair[1]); } } return null; } ``` 使用示例: ```javascript let username = getCookie("username"); // 获取名为 "username" 的 Cookie 值 ``` 3. 删除 Cookie:通过设置 Cookie 的过期时间为过去的时间来删除 Cookie封装一个函数如下: ```javascript function deleteCookie(name) { document.cookie = name + "=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;"; } ``` 使用示例: ```javascript deleteCookie("username"); // 删除名为 "username" 的 Cookie ``` 这样,你可以封装这些函数,以便在需要的时候方便地操作 Cookie
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值