转自:http://www.cnblogs.com/yjzhu/archive/2012/11/26/2789032.html

一、什么是 cookie?

cookie 就是页面用来保存信息,比如自动登录、记住用户名等等。

二、cookie 的特点

  1. 同个网站中所有的页面共享一套 cookie;
  2. cookie 有数量、大小限制;
  3. cookie 有过期时间。

三、如何使用 cookie?

通过 document.cookie 来写入 cookie

<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>cookie基础</title>
</head>
<body>
<script type="text/javascript">
    document.cookie = 'username=abc';
    document.cookie = 'password=123';
    document.cookie = 'email=abcdef@123.com';
  </script>
</body>
</html>

打开浏览器查看 cookie,可以发现新定义的 cookie 并不会将原来的覆盖。

如果没有设置过期时间,那么关闭浏览器就会清空 cookie。如何设置过期时间呢?答案是:expires。一般我们会结合 Date 对象来使用。

var d = new Date();
d.setTime(d.getTime() + 1 * 3600 * 1000);
document.cookie = 'username=abc; expires=' + d.toGMTString();

我们可以通过火狐浏览器看到,username 的过期时间是当前时间的 1 小时后。

最后对获取 cookie 的方法进行封装:

function setCookie(name,value,hours){
var d = new Date();
d.setTime(d.getTime() + hours * 3600 * 1000);
document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}

学会了如何设置 cookie,那么该如何读取 cookie 呢?

首先我们看下 cookie 里的内容是什么类型?

document.cookie = 'username=abc';
document.cookie = 'password=123';
document.cookie = 'email=abcdef@123.com';
typeof document.cookie; //string
alert(document.cookie); //'username=abc; password=123; email=abcdef@123.com'

得到的是一串字符串,需要注意的是,每个 ; 后面都有个空格。

那么我们如何取到具体的数值呢?附上代码:

function getCookie(name){
var arr = document.cookie.split('; ');
for(var i = 0; i < arr.length; i++){
var temp = arr[i].split('=');
if(temp[0] == name){
return temp[1];
}
}
return '';
}

除了设置、获取 cookie,我们还可以删除 cookie。我们在网上经常看到有清除用户名这样的功能,其实就是用到了清除 cookie。

清除 cookie 其实很简单,只要使过期时间为过去时间就可以了。

function removeCookie(name){
var d = new Date();
d.setTime(d.getTime() - 10000);
document.cookie = name + '=1; expires=' + d.toGMTString();
}

最后我们将设置、获取、清除 cookie 封装成一个 cookie.js

function setCookie(name,value,hours){
var d = new Date();
d.setTime(d.getTime() + hours * 3600 * 1000);
document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}
function getCookie(name){
var arr = document.cookie.split('; ');
for(var i = 0; i < arr.length; i++){
var temp = arr[i].split('=');
if(temp[0] == name){
return temp[1];
}
}
return '';
}
function removeCookie(name){
var d = new Date();
d.setTime(d.getTime() - 10000);
document.cookie = name + '=1; expires=' + d.toGMTString();
}

最新文章

  1. SpringMVC+FreeMarker
  2. 使用Roboguice依赖注入规划Android项目
  3. HorizontalScrollView实现先左滑动后右滑动动画
  4. H2Database数据类型
  5. WAMP Server助你在Windows上快速搭建PHP集成环境
  6. clientTop、clientWidth、offsetTop、offsetWidth、scrollTop
  7. Asp.Net连接Mysql报错Out of sync with server
  8. css-a:visited
  9. java中输出流OutputStream 类应用实例(转)
  10. SPFile上传文件到文档库
  11. 1、Zookeeper熟悉和用途综述
  12. Gas Station [leetcode] 两个解决方案
  13. WITH (NOLOCK)浅析
  14. 设置自己Eclipse代码风格(内部)
  15. Linux 访问控制列表(access control list)
  16. 记一次解决非法参数DDoS攻击的实践
  17. Spring整合Web项目原理-理解不了,忽略
  18. 选择困难症的福音——团队Scrum冲刺阶段-Day 1领航
  19. 不一样的go语言-不同的语法之type
  20. CentOS7 配置静态IP

热门文章

  1. 44- EF + Identity实现
  2. ABAP CDS ON HANA-(4)ヘッダー行編集
  3. Java线程和多线程(十)——TimerTask
  4. Linux 下 PHP 扩展Soap 编译安装
  5. hihoCoder 1175:拓扑排序二
  6. 近期准备发布我的asp.net框架
  7. ProxySQL读写分离测试(续)
  8. 在阿里云上遇见更好的Oracle(一)
  9. SIP初步
  10. 利用Github Pages建立仓库“门面”