【javascript】cookie 基础

一、什么是 cookie?


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


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


三、如何使用 cookie?


通过 document.cookie 来写入 cookie

  1. <!DOCTYPE HTML>
  2. <html lang="en-US">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>cookie基础</title>
  6. </head>
  7. <body>
  8.     
  9. </body>
  10. </html>
  11. <script type="text/javascript">
  12. document.cookie = 'username=abc';
  13. document.cookie = 'password=123';
  14. document.cookie = '[email protected]';
  15. </script>
复制代码

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


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

  1. var d = new Date();
  2. d.setTime(d.getTime() + 1 * 3600 * 1000);
  3. document.cookie = 'username=abc; expires=' + d.toGMTString();
复制代码

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


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

  1. function setCookie(name,value,hours){  
  2.     var d = new Date();
  3.     d.setTime(d.getTime() + hours * 3600 * 1000);
  4.     document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
  5. }
复制代码

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


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

  1. document.cookie = 'username=abc';
  2. document.cookie = 'password=123';
  3. document.cookie = '[email protected]';
  4. typeof document.cookie;    //string
  5. alert(document.cookie);    //'username=abc; password=123; [email protected]'
复制代码

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


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

  1. function getCookie(name){  
  2.     var arr = document.cookie.split('; ');
  3.     for(var i = 0; i < arr.length; i++){
  4.         var temp = arr[i].split('=');
  5.         if(temp[0] == name){
  6.             return temp[1];
  7.         }
  8.     }
  9.     return '';
  10. }
复制代码

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


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

  1. function removeCookie(name){
  2.     var d = new Date();
  3.     d.setTime(d.getTime() - 10000);
  4.     document.cookie = name + '=1; expires=' + d.toGMTString();
  5. }
复制代码

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

  1. function setCookie(name,value,hours){  
  2.     var d = new Date();
  3.     d.setTime(d.getTime() + hours * 3600 * 1000);
  4.     document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
  5. }
  6. function getCookie(name){  
  7.     var arr = document.cookie.split('; ');
  8.     for(var i = 0; i < arr.length; i++){
  9.         var temp = arr[i].split('=');
  10.         if(temp[0] == name){
  11.             return temp[1];
  12.         }
  13.     }
  14.     return '';
  15. }
  16. function removeCookie(name){
  17.     var d = new Date();
  18.     d.setTime(d.getTime() - 10000);
  19.     document.cookie = name + '=1; expires=' + d.toGMTString();
  20. }
复制代码

PS:附上 cookie 应用的小实例点击这里

http://bbs.html5cn.org/thread-86790-1-1.html

猜你喜欢

转载自soledede.iteye.com/blog/2197054
今日推荐