作者:林禎峰佩蓉 | 来源:互联网 | 2021-10-28 19:08
问题:
使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据。比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置。
解决方案:
在用户浏览页面并进行设置时,将这些设置保存在COOKIE中,下次访问的时候读取COOKIE中的设置。
参考下面的脚本:
代码如下:
// utility function to retrieve an expiration data in proper format;
function getExpDate(days, hours, minutes)
{
var expDate = new Date();
if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")
{
expDate.setDate(expDate.getDate() + parseInt(days));
expDate.setHours(expDate.getHours() + parseInt(hours));
expDate.setMinutes(expDate.getMinutes() + parseInt(minutes));
return expDate.toGMTString();
}
}
//utility function called by getCOOKIE()
function getCOOKIEVal(offset)
{
var endstr = document.COOKIE.indexOf(";", offset);
if(endstr == -1)
{
endstr = document.COOKIE.length;
}
return unescape(document.COOKIE.substring(offset, endstr));
}
// primary function to retrieve COOKIE by name
function getCOOKIE(name)
{
var arg = name + "=";
var alen = arg.length;
var clen = document.COOKIE.length;
var i = 0;
while(i {
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;
}
// store COOKIE value with optional details as needed
function setCOOKIE(name, value, expires, path, domain, secure)
{
document.COOKIE = name + "=" + escape(value) +
((expires) ? "; expires=" + expires : "") +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
((secure) ? "; secure" : "");
}
// remove the COOKIE by setting ancient expiration date
function deleteCOOKIE(name,path,domain)
{
if(getCOOKIE(name))
{
document.COOKIE = name + "=" +
((path) ? "; path=" + path : "") +
((domain) ? "; domain=" + domain : "") +
"; expires=Thu, 01-Jan-70 00:00:01 GMT";
}
}
使用getCOOKIE(name)函数来读取COOKIE中保存的值,参数name为COOKIE项的名称。如果该COOKIE项不存在则返回一个空字符串。
使用setCOOKIE()函数来保存COOKIE项的值,其中第一、二两个参数分别为COOKIE项的名称和值。如果想为其设置一个过期时间,那么就需要设置第三个参数,这里需要通过getExpDate()获得一个正确格式的参数。
最后,使用deleteCOOKIE()来删除一个已存在的COOKIE项,实际上是通过让该项过期。
COOKIE将数据保存在客户端。页面的脚本只能读取所在域和服务器的COOKIE值,如果域内有多个服务器,那么需要设置第五个参数,以指定服务器。浏览器的容量一般限定为每服务器20个name/value对,每个COOKIE项不超过4000个字符,更现实点,单个COOKIE项应少于2000字符,也就是说不要用COOKIE在客户端保存大容量数据。
不同的浏览器保存COOKIE的方式也有所不同。IE为每个域的COOKIE建立一个文本文件,而Netscape则将所有的COOKIE存储在同一个文本文件中。
注意:COOKIE存放在客户端,所以会受到浏览器设置的影响,比如用户可能会禁用COOKIE。要检测浏览器是否支持COOKIE,使用属性navigator.COOKIEEnabled来判断。
12下一页阅读全文