中国第一Ajax站长门户:www.okajax.com   虚拟主机 域名注册 云主机

js操作cookie的函数,来自jquery - okajax.com - Ajax中国

我要投稿 会员登陆 RSS订阅 本站推荐:
您的位置主页 > 网页设计 > Javascript&js > js操作cookie的函数,来自jquery

js操作cookie的函数,来自jquery

2011-06-29    文章来源:互联网    浏览次数:

jquery没有直接操作cookie的函数,所以我们可以写一个cookie的操作函数,也可以下载一个jquery cookie插件,或者直接把jquery cookie函数拿来用。

1、正常思路的普通写法。

 

  1. //1.创建Cookie    我们要进行的第一件事就是要创建一个Cookie。下面给出的SctCookie()函数将完成这一功能。     
  2. function SetCookie (name, value)  
  3. {       
  4. var argv=SetCookie.arguments;       
  5. var argc=SetCookie.arguments.length;       
  6. var expires=(argc>2)?argv[2]: null;       
  7. var path=(argc>3)? argv[3]: null;       
  8. var domain=(argc>4)? argv[4]: null;       
  9. var secure=(argc>5)? argv[5]: false;       
  10. document.cookie=name+"="+escape(value)+((expires==null)?"":";expires="+expires.toGMTString()))+ ((path==null)?"":(";path="+path))+  ((domain==null)?"":(";domain="+ domain))+ ((secure==true)?";secure":"");     
  11. }     
  12. //SetCookie()只要求传递被设置的Cookie的名字和值,但如果必要的话你可以设置其他4 个参数而不必改变这个函数。可选的参数必须用正确的次序使用。如果不想设置某个参数, 必须设置一个空串。比如,如果我们创建的一个Cookie需要指定secure域,但不想设置expir es, patb或domain,就可以像这样调用SetCookie():  SetCookie("MyNewCookie","MyValue" ,"",","tyue);     
  13. ////////////////////////  
  14. //2.读取Cookie     
  15. //下面给出的函数GetCookie()用来读取一个Cookie。当一个Cookie的请求被客户机收到时,该客户机查找它的cookies.txt文件以进行匹配。这个函数首先匹配这个Cookie的名字。如果有多个同名的Cookie,它再匹配路径。函数完成匹配后返回这个Cookie的值。如果客户机中没有这个Cookie,或者路径不匹配,该函数返回一个NULL。     
  16. function GetCookie(name)  
  17. {       
  18. var arg=name+ "=";       
  19. var alen=arg.length;       
  20. var clen=document.cookie.length;       
  21. var i=0;       
  22. while (i<clen) {         
  23. var j=i+alen;         
  24. if(document.cookie.substring(i,j) ==arg)         
  25. return getCookieVal(j);         
  26. i=document.cookie.indexOf("",i)+1;         
  27. if(i==0)break;      }       
  28. return null;    }  

2、直接把jquery的cookie操作函数拿来用。

  1. jQuery.cookie = function(name, value, options) {     
  2.     if (typeof value != 'undefined') { // name and value given, set cookie       
  3.         options = options || {};     
  4.         if (value === null) {     
  5.             value = '';     
  6.             options.expires = -1;     
  7.         }     
  8.         var expires = '';     
  9.         if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {     
  10.             var date;     
  11.             if (typeof options.expires == 'number') {     
  12.                 date = new Date();     
  13.                 date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));     
  14.             } else {     
  15.                 date = options.expires;     
  16.             }     
  17.             expires = '; expires=' + date.toUTCString();     
  18.         }     
  19.         var path = options.path ? '; path=' + (options.path) : '';     
  20.         var domain = options.domain ? '; domain=' + (options.domain) : '';     
  21.         var secure = options.secure ? '; secure''';     
  22.         document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');     
  23.     } else {     
  24.         var cookieValue = null;     
  25.         if (document.cookie && document.cookie != '') {     
  26.             var cookies = document.cookie.split(';');     
  27.             for (var i = 0; i < cookies.length; i++) {     
  28.                 var cookie = jQuery.trim(cookies[i]);     
  29.                 if (cookie.substring(0, name.length + 1) == (name + '=')) {     
  30.                     cookieValue = decodeURIComponent(cookie.substring(name.length + 1));     
  31.                     break;     
  32.                 }     
  33.             }     
  34.         }     
  35.         return cookieValue;     
  36.     }     
  37. };    
  38.  
  39. //使用方法如下:  
  40. //设置cookie的键值对  
  41. //$.cookie(’name’, ‘value’);  
  42. //设置cookie的键值对,有效期,路径,域,安全  
  43. //$.cookie(’name’, ‘value’, {expires: 7, path: ‘/’, domain: ‘jquery.com’, secure: true});  
  44. //新建一个cookie 包括有效期 路径 域名等  
  45. //读取cookie的值  
  46. //var account= $.cookie(’name’);  
  47. //删除一个cookie  
  48. //example $.cookie(’name’, null);  

 

文章评论(查看全部)

看不清楚?单击换一张。
loading.. 评论加载中....
关于我们 - 广告服务 - 版权隐私 - 免责声明 - RSS地图 - 网站地图 - 使用帮助 - 返回顶部