您的位置:首页 > Web前端 > JavaScript

JavaScript操作Cookie详解

2008-04-05 00:30 585 查看
Cookie是JavaScript中的一种机制,可以实现严格的跨页面全局变量的要求。

Cookie是存于用户硬盘的一个文件,这个文件通常对应于一个域名,当浏览器再次访问这个域名时,便使这个cookie可用。因此,cookie可以跨越一个域名下的多个网页,但不能跨越多个域名使用。

在Cookie设置中,用escape()函数进行编码,可避免乱码和特殊字符问题; 当使用escape()编码后,在取出值以后需要使用unescape()进行解码才能得到原来的cookie值。

设置Cookie时可以直接给document.cookie赋值:

document.cookie="userId=828";

document.cookie="userName=hulk";
而且后面的值不会覆盖前面的值,它具有一种累加机制。

cookie的值可以由document.cookie直接获得,但这样获取的是所有的cookie值;要通过一指定cookie名称来获得所对应的值,则需做一些处理。

构造通用的cookie处理函数:

1.添加一个cookie:addCookie(name,value,expireHours)

该函数接收3个参数:cookie名称,cookie值,以及在多少小时后过期。这里约定expireHours为0时不设定过期时间,即当浏览器关闭时cookie自动消失。该函数实现如下:

<script language="JavaScript" type="text/javascript">

<!--

function addCookie(name,value,expireHours){

var cookieString=name+"="+escape(value);

//判断是否设置过期时间

if(expireHours>0){

var date=new Date();

date.setTime(date.getTime+expireHours*3600*1000); // 转换为毫秒

cookieString=cookieString+"; expire="+date.toGMTString();

}

document.cookie=cookieString;

}

//-->

</script>

2.获取指定名称的cookie值:getCookie(name)

该函数返回名称为name的cookie值,如果不存在则返回空,其实现如下:

<script language="JavaScript" type="text/javascript">

<!--

function getCookie(name){

var strCookie=document.cookie;

var arrCookie=strCookie.split("; "); // 将多cookie切割为多个名/值对

for(var i=0;i<arrCookie.length;i++){ // 遍历cookie数组,处理每个cookie对

var arr=arrCookie[i].split("="); // 找到名称为userId的cookie,并返回它的值

if(arr[0]==name)

return arr[1];

}

return "";

}

//-->

</script>

3.删除指定名称的cookie:deleteCookie(name)

该函数可以删除指定名称的cookie,其实现如下:

<script language="JavaScript" type="text/javascript">

<!--

function deleteCookie(name){

var date=new Date();

date.setTime(date.getTime()-10000); // 删除一个cookie,就是将其过期时间设定为一个过去的时间

document.cookie=name+"=v; expire="+date.toGMTString();

}

//-->

</script>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: