收藏本站腾讯微博新浪微博

经典论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

蓝色理想 最新研发动态 网站开通淘帖功能 - 蓝色理想插件 论坛内容导读一页看论坛 - 给官方提建议

论坛活动及任务 地图和邮件任务 请多用悬赏提问 热夏来袭,选一款蓝色理想的个性T恤吧!

手机上论坛,使用APP获得更好体验 急需前端攻城狮,获得内部推荐机会 论坛开通淘帖功能,收藏终于可以分类了!

搜索
查看: 1035|回复: 0

[技术相关] JavaScript也能操纵cookie函数

[复制链接]
发表于 2014-7-3 10:32:00 | 显示全部楼层 |阅读模式
jquery没有直接操作cookie的函数,但我们可以写一个cookie的操作函数,也可以下载一个jquery cookie插件,或者直接把jquery cookie函数拿来用,这些方法都是可行的,以下文章中介绍一些基本写法。

正常思路的普通写法。

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

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

jQuery.cookie = function(name, value, options) {     
    if (typeof value != 'undefined') { // name and value given, set cookie      
        options = options || {};     
        if (value === null) {     
            value = '';     
            options.expires = -1;     
        }     
        var expires = '';     
        if (options.expires && (typeof options.expires == 'number' || options.expires.toUTCString)) {     
            var date;     
            if (typeof options.expires == 'number') {     
                date = new Date();     
                date.setTime(date.getTime() + (options.expires * 24 * 60 * 60 * 1000));     
            } else {     
                date = options.expires;     
            }     
            expires = '; expires=' + date.toUTCString();     
        }     
        var path = options.path ? '; path=' + (options.path) : '';     
        var domain = options.domain ? '; domain=' + (options.domain) : '';     
        var secure = options.secure ? '; secure': '';     
        document.cookie = [name, '=', encodeURIComponent(value), expires, path, domain, secure].join('');     
    } else {     
        var cookieValue = null;     
        if (document.cookie && document.cookie != '') {     
            var cookies = document.cookie.split(';');     
            for (var i = 0; i < cookies.length; i++) {     
                var cookie = jQuery.trim(cookies[i]);     
                if (cookie.substring(0, name.length + 1) == (name + '=')) {     
                    cookieValue = decodeURIComponent(cookie.substring(name.length + 1));     
                    break;     
                }     
            }     
        }     
        return cookieValue;     
    }     
};   

//使用方法如下:  
//设置cookie的键值对  
//$.cookie(’name’, ‘value’);  
//设置cookie的键值对,有效期,路径,域,安全  
//$.cookie(’name’, ‘value’, {expires: 7, path: ‘/’, domain: ‘jquery.com’, secure: true});  
//新建一个cookie 包括有效期 路径 域名等  
//读取cookie的值  
//var account= $.cookie(’name’);  
//删除一个cookie  
//example $.cookie(’name’, null);  
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|Archiver|手机版|blueidea.com ( ICP05002321 )  

GMT+8, 2019-10-17 21:32 , Processed in 0.077927 second(s), 7 queries , Gzip On, Memcache On.

Powered by Discuz! X3.2 Licensed

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表