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

javascript中的cookie使用(javascript权威指南)

2010-11-05 09:53 423 查看
jquery.cookie.js 使用方法:

jQuery操作cookie的插件,大概的使用方法如下

$.cookie('the_cookie'); //读取Cookie值

$.cookie('the_cookie', 'the_value'); //设置cookie的值

$.cookie('the_cookie', 'the_value', {expires: 7, path: '/', domain: 'jquery.com', secure: true});//新建一个cookie 包括有效期 路径 域名等

$.cookie('the_cookie', 'the_value'); //新建cookie

$.cookie('the_cookie', null); //删除一个cookie

==========================================================================

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">

<HTML>

<HEAD>

<TITLE> New Document </TITLE>

<META NAME="Generator" CONTENT="EditPlus">

<META NAME="Author" CONTENT="">

<META NAME="Keywords" CONTENT="">

<META NAME="Description" CONTENT="">

<SCRIPT LANGUAGE="JavaScript">

<!--

//cookie的存储,例如:下面时设置终止日期。

var nextyear=new Date();

nextyear.setFullYear(nextyear.getFullYear()+1);

document.cookie="version="+document.lastModified+";expires="+nextyear.toGMTString();

//-->

</SCRIPT>

<SCRIPT LANGUAGE="JavaScript">

<!--

//cookie的读取

//读cookie属性,这将返回文档的所有cookie

var allcookies=document.cookie;

//查找名为的的开始位置

var pos=allcookies.indexOf("version=");

if(pos!=-1){

var start=pos+8;

var end=allcookies.indexOf(";",start);

if(end==-1) end=allcookies.length;

var value=allcookies.substring(start,end);

value=unescape(value); //escape()函数用于编码, unescape()用于解码

//既然我们已经有了cookie的值,就可以使用它。

//在这种情况下,cookies之前被设置为文档的修改日期。

if(value!=document.lastModified) //lastModified一个字符串对象,包含文档的最近修改日期

alert("this document has changed since you were last here");

else

alert("this document has not changed");

}

//-->

</SCRIPT>

<SCRIPT LANGUAGE="JavaScript">

<!--

//使用cookie时的一个工具类(面向对象,原型)

//构造函数:用指定的名字和可选的性质为指定的文档创建一个cookie对象。

//参数:

//document:保存cookie的Document对象,必须的。

//name:指定cookie名的字符串。必须的。

//hours:一个可选的数字,指定从现在起到过期时间的小时数

//path:一个可选的字符串,指定了cookie的路径性质

//domain:一个可选的字符串,指定了cookie的域性质

//secure:一个可选的布尔值,为true ,需要一个安全的cookie

function Cookie(document, name, hours, path, domain, secure)

{

// 该对象的所有预定义的属性都以'$'开头。

// 这是为了与存储在cookie中的属性值区分开。

this.$document = document;

this.$name = name;

if (hours) //当字符串为空时,为false, 不为空时,为true

this.$expiration = new Date((new Date()).getTime() + hours*3600000);

else this.$expiration = null;

if (path) this.$path = path; else this.$path = null;

if (domain) this.$domain = domain; else this.$domain = null;

if (secure) this.$secure = true; else this.$secure = false;

}

// 该函数是cookie对象的 store() 方法。

Cookie.prototype.store = function () {

// 首先,遍历cookie对象的属性,并且将cookie值连接起来。

// 由于cookie将等号和分号作为分隔符。

// 所以我们使用冒号和&来分隔存储在单个cookie值中的状态变量。

// 注意:我们对每个状态变量的值进行了转义,以防它含有标点符号或其它非法字符。

var cookieval = "";

for(var prop in this) {

// 忽略所有名字以$开头的属性和所有方法(typeof的用法)

if ((prop.charAt(0) == '$') || ((typeof this[prop]) == 'function'))

continue;

if (cookieval != "") cookieval += '&';

cookieval += prop + ':' + escape(this[prop]);

}

// 既然我们已经有了cookie只,就可以连接完成的cookie串。

//其中包括名字和创建cookie对象时指定的各种性质.

var cookie = this.$name + '=' + cookieval;

if (this.$expiration)

cookie += '; expires=' + this.$expiration.toGMTString();

if (this.$path) cookie += '; path=' + this.$path;

if (this.$domain) cookie += '; domain=' + this.$domain;

if (this.$secure) cookie += '; secure';

// 下面设置Document.cookie属性来保存cookie

this.$document.cookie = cookie;

}

// 该函数是cookie对象的load()方法

Cookie.prototype.load = function() {

// 首先得到属于该文档的所有cookie的列表,

// 通过读Document.cookie属性可以实现这一点.

var allcookies = this.$document.cookie;

if (allcookies == "") return false;

// 下面从该列表中提取已命名的cookie.

var start = allcookies.indexOf(this.$name + '=');

if (start == -1) return false; // 该页未定义cookie

start += this.$name.length + 1; // 跳过名字和等号.

var end = allcookies.indexOf(';', start);

if (end == -1) end = allcookies.length;

var cookieval = allcookies.substring(start, end);

// 既然我们已经提取出了已命名的cookie 的值,就可以把它分割存储到状态变量名和值.

// 名字/值对由&分隔,名字和值之间则由冒号分隔.

//我们使用split()方法解析所有数据.

var a = cookieval.split('&');//a 表示一个数组了 // 分隔成名字/值对.

for(var i=0; i < a.length; i++) // 把每对值存入数组.

a[i] = a[i].split(':'); //a表示二维数组

// 既然我们已经解析了cookie值

// 就可以设置cookie对象中的状态变量的名字和值.

// 注意我们对属性值调用了unescape(),因为存储它们时调用了escape()方法.

for(var i = 0; i < a.length; i++) {

this[a[i][0]] = unescape(a[i][1]); //a[][]参数从0开始.

}

// 返回成功

return true;

}

// 该函数是cookie对象的remove() 方法.

Cookie.prototype.remove = function() {

var cookie;

cookie = this.$name + '=';

if (this.$path) cookie += '; path=' + this.$path;

if (this.$domain) cookie += '; domain=' + this.$domain;

cookie += '; expires=Fri, 02-Jan-1970 00:00:00 GMT';

this.$document.cookie = cookie; //原来的被覆盖了.

}

//-->

</SCRIPT>

<SCRIPT LANGUAGE="JavaScript">

<!--

// 使用该工具类的实例

var visitordata = new Cookie(document, "name_color_count_state", 240); //240小时就是10天

if (!visitordata.load() || !visitordata.name || !visitordata.color) {

visitordata.name = prompt("What is your name:", "");

visitordata.color = prompt("What is your favorite color:", "");

}

// 跟踪这个用户访问了多少次该页面:

if (visitordata.visits == null) visitordata.visits = 0;

visitordata.visits++;

visitordata.store();

document.write('<font size="7" color="' + visitordata.color + '">' +

'Welcome, ' + visitordata.name + '!' +

'</font>' +

'<p>You have visited ' + visitordata.visits + ' times.');

//-->

</SCRIPT>

</HEAD>

<BODY>

<form>

<input type="button" value="Forget My Name" onclick="visitordata.remove();">

</form>

</BODY>

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