1、建立Cookie對象
//因為是作為類名或者命名空間的使用,所以和Math對象類似,這裡使用Cookie來表示該對象
var Cookie = new Object();
2、實現設定Cookie的方法
//name是要設定cookie的名稱;value是設定cookie的值,option包括了其它選項,是一個對象作為參數
Cookie.setCookie = function(name, value, option) {
//用於儲存賦值給document.cookie的cookie格式字串
var str = name+"="+escape(value);
if(option) {
//如果設定了到期時間
if(option.expireDays) {
var date = new date();
var ms = option.expireDays*24*3600*1000;
date.setTime(date.getTime()+ms);
str += "; expires="+date.toGMTString();
}
if(option.path) str += "; path="+path;//設定訪問路徑
if(option.domain) str += "; domain="+domain;//設定訪問主機
if(option.secure) str += "; true";//設定安全性
}
document.cookie = str;
}
3、實現取Cookie的方法
//name是指定cookie的名稱,從而根據名稱返回相應的值
Cookie.getCookie = function(name) {
var cookieArray = document.cookie.split("; ");//得到分割的cookie名值對
var cookie = new Object();
for(var i=0; i<cookieArray.length; i++) {
var arr = cookieArray[i].split("=");//將名和值分開
if(arr[0]==name) return unescape(arr[1]);//如果是指定的cookie,則返回它的值
}
return "";
}
4、實現刪除Cookie的方法
//name是指定cookie的名稱,從而根據這個名稱刪除相應的cookie。在實現中,刪除cookie是通過調用setCookie來完成的,將option的expireDays屬性指定為負數即可
Cookie.deleteCookie = function(name) {
this.setCookie(name, "", {expireDays:-1});//將到期時間設定為過去來刪除一個cookie
}
通過下面的代碼,整個Cookie對象建立完畢後,可以將其放到一個大括弧中來定義:
var Cookie = {
setCookie:function(){},
getCookie:function(){},
deleteCookie:function(){}
}
通過這種形式,可以讓Cookie的功能更加清晰,它作為一個全域對象,大大方便了對Cookie的操作
Cookie.setCookie("user", "terry");
Cookie.deleteCookie("user");