Rumah >hujung hadapan web >tutorial js >javascript操作cookie方法函数集合

javascript操作cookie方法函数集合

PHP中文网
PHP中文网asal
2016-05-16 18:23:401422semak imbas

问题:
使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据。比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置。
解决方案:
在用户浏览页面并进行设置时,将这些设置保存在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 < 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; 
} 
// 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来判断。

<script> 
//写cookies函数 作者:翟振凯 
function 
SetCookie(name,value)//两个参数,一个是cookie的名子,一个是值 
{ 
var Days = 30; //此 
cookie 将被保存 30 天 
var exp = new Date(); //new Date("December 31, 9998"); 
exp.setTime(exp.getTime() + Days*24*60*60*1000); 
document.cookie = name 
+ "="+ escape (value) + ";expires=" + exp.toGMTString(); 
} 
function 
getCookie(name)//取cookies函数 
{ 
var arr = document.cookie.match(new 
RegExp("(^| )"+name+"=([^;]*)(;|$)")); 
if(arr != null) return 
unescape(arr[2]); return null; 
} 
function delCookie(name)//删除cookie 
{ 
var exp = new Date(); 
exp.setTime(exp.getTime() - 1); 
var 
cval=getCookie(name); 
if(cval!=null) document.cookie= name + 
"="+cval+";expires="+exp.toGMTString(); 
} 
SetCookie ("xiaoqi", "3") 
alert(getCookie(&#39;xiaoqi&#39;)); 
</script>

一个非常实用的javascript读写Cookie函数

function GetCookieVal(offset) 
//获得Cookie解码后的值 
{ 
var endstr = 
documents.cookie.indexOf (";", offset); 
if (endstr == -1) 
endstr = 
documents.cookie.length; 
return unescape(documents.cookie.substring(offset, 
endstr)); 
} 
function SetCookie(name, value) 
//设定Cookie值 
{ 
var expdate = new Date(); 
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; 
if(expires!=null) expdate.setTime(expdate.getTime() + ( expires * 1000 )); 
documents.cookie = name + "=" + escape (value) +((expires == null) ? "" : 
("; expires="+ expdate.toGMTString())) 
+((path == null) ? "" : ("; path=" + 
path)) +((domain == null) ? "" : ("; domain=" + domain)) 
+((secure == true) 
? "; secure" : ""); 
} 
function DelCookie(name) 
//删除Cookie 
{ 
var exp = new Date(); 
exp.setTime (exp.getTime() - 1); 
var cval = 
GetCookie (name); 
documents.cookie = name + "=" + cval + "; expires="+ 
exp.toGMTString(); 
} 
function GetCookie(name) 
//获得Cookie的原始值 
{ 
var arg = name + "="; 
var alen = arg.length; 
var clen = 
documents.cookie.length; 
var i = 0; 
while (i < clen) 
{ 
var j 
= i + alen; 
if (documents.cookie.substring(i, j) == arg) 
return 
GetCookieVal (j); 
i = documents.cookie.indexOf(" ", i) + 1; 
if (i == 0) 
break; 
} 
return null; 
} 

<SCRIPT language="javascript"> 
<!-- 
function openpopup(){ 
url="popup.htm" 
window.open("gonggao.htm","gonggao","width=260,height=212,left=200,top=0") 
} 
function get_cookie(Name) { 
var search = Name + "=" 
var 
returnvalue = ""; 
if (documents.cookie.length > 0) { 
offset = 
documents.cookie.indexOf(search) 
if (offset != -1) { 
offset += 
search.length 
end = documents.cookie.indexOf(";", offset); 
if (end == 
-1) 
end = documents.cookie.length; 
returnvalue=unescape(documents.cookie.substring(offset, end)) 
} 
} 
return returnvalue; 
} 
function helpor_net(){ 
if 
(get_cookie(&#39;popped&#39;)==&#39;&#39;){ 
openpopup() 
documents.cookie="popped=yes" 
} 
} 
helpor_net() 
//--> 
</SCRIPT>

如果点了确定,只要不清cookie,以后访问都不会再提示,如果不点确定则每次都会提示。放在js文件里,全站包含 

<SCRIPT LANGUAGE="JavaScript"> 
<!-- 
var the_cookie = 
document.cookie; 
var broken_cookie = the_cookie.split(":"); 
var 
the_visiteraccepted = unescape(broken_cookie[1]); 
// 
if 
(the_visiteraccepted=="undefined"){ 
var tmp=confirm(&#39;中国人何时何地。&#39;); 
if(tmp==false){ 
window.close(); 
}else{ 
var the_visiteraccepted = 
1; 
var the_cookie = "ILoveChina=visiteraccepted:" + 
escape(the_visiteraccepted); 
document.cookie = the_cookie; 
} 
} 
//--> 
</SCRIPT>

1. Cookie的兼容性问题
Cookie的格式有2个不同的版本,第一个版本,我们称为Cookie Version 0,是最初由Netscape公司制定的,也被几乎所有的浏览器支持。而较新的版本,Cookie Version 1,则是根据RFC 2109文档制定的。为了确保兼容性,JAVA规定,前面所提到的涉及Cookie的操作都是针对旧版本的Cookie进行的。而新版本的Cookie目前还不被Javax.servlet.http.Cookie包所支持。
2. Cookie的内容
同样的Cookie的内容的字符限制针对不同的Cookie版本也有不同。在Cookie Version 0中,某些特殊的字符,例如:空格,方括号,圆括号,等于号(=),逗号,双引号,斜杠,问号,@符号,冒号,分号都不能作为Cookie的内容。这也就是为什么我们在例子中设定Cookie的内容为"Test_Content"的原因。
虽然在Cookie Version 1规定中放宽了限制,可以使用这些字符,但是考虑到新版本的Cookie规范目前仍然没有为所有的浏览器所支持,因而为保险起见,我们应该在Cookie的内容中尽量避免使用这些字符  

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn