JavaScript中的cookie

  cookie本身没什么可介绍的,但是cookie在JavaScript中,有很多需要注意的

  首先,cookie在JavaScript中,是window.document对象的一个属性,所以访问cookie是通过document.cookie这种形式。

设置cookie值

  最直接的方式是下面这样:

<!--- demo.html -->

<!DOCTYPE html>
<html>
<head>
	<meta charset="UTF-8">
	<title>Document</title>
</head>
<body>
	<input type="button" value="跳转" id="btn">
</body>
<script>
	document.cookie = "name=abc";
	document.cookie = "age=20";

	var btn = document.getElementById("btn");
	btn.onclick= function(){
		window.open("index.php","_blank");
	}
</script>
</html>

  

查看cookie

  方式1,使用PHP的超全局数组来读取,注意运行的另外一个文件了,不是保存cookie的那个文件:

/*  index.php */

<?php 
    print_r($_COOKIE);
 ?>

  方式二:使用document.cookie来set值,那么仍旧可以使用document.cookie来get值,不过仍旧不是保存cookie的那个文件。

<!-- index.php  -->
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>打印cookie</title>
</head>
<body></body>
<script>
    alert(document.cookie);
</script>
</html>

  上面两个查看cookie的代码都保存在另外一个文件中(index.php),而不是保存cookie的demo.html,这是因为在demo.html中无论怎么设置,无论刷新多少次,都不会出现cookie值,这是因为cookie的特性。

  简而言之:在页面中设置cookie的那一次,是读不到cookie的,因为本次设置的cookie要下次才能生效,而不断地刷新,cookie就不断地重新保存,于是就始终取不到cookie的值。同时cookie是有作用范围的,也就是不能访问不同域的cookie,通常只能访问本域的cookie,所以可以在同一个域中范文设置的cookie,即在一个程序(demo.html)中设置,在另外一个程序中(index.php)中获取,demo.html和index.php都在同一个域下(localhost)。

  

  下面是使用PHP的全局数组打印出的cookie内容如下:

Array
(
    [name] => abc
    [age] => 20
)

  

  下面是使用打印document.cookie的信息,如下:

name=abc; age=20

  

  可以看到,虽然在demo.html中,对document.cookie赋了两次值,一次是name=abc,一次是age=20,但是在这里,第二次赋值并没有覆盖掉第一次赋的值,反而两个都保存了,而且使用document.cookie的形式是以字符串保存,不同的项用分号加空格来分隔,但是我们在设置多项的cookie的时候,可以使用一下形式,中间直接用分号分隔,但最好使用cookie。

document.cookie = "name=abc; age=20"

  

设置过期时间

  设置cookie的过期时间,和php差不多,都是当前时间加上过期时间,即在那个时间点。有点不同的是,php中过期时间的单位是秒,格式如下:

//php中的用法
setcookie("attr", $value, time()+3600);  /* 1 小时过期  */

  但是JavaScript更加方便一点,可以直接设置几天过期,几年过期

<script>
	var date = new Date();
	
	//date.setFullYear(date.getFullYear() + 1);//一年后过期
	//date.setMonth(date.getMonth() + 1 + 2);//2个月后过期,注意多加一个1
	//date.setDate(date.getDate() + 1);//一天后
	date.setSeconds(date.getSeconds() + 30);//30s后过期

	document.cookie = "name=abc;expires=" + date;
	document.cookie = "age=20";

	var btn = document.getElementById("btn");
	btn.onclick= function(){
		window.open("test.html","_blank");
	}
</script>

  

  需要注意的是,上面这些setDate,setMonth,setFullYear不能叠加,只能设置一项,因为使用php习惯了,随意推荐使用秒作单位。

  还有一个要注意:如果使用简短方式设置cookie和过期时间,如下

document.cookie = "name=abc; expires=" + (过期时间1)"; "age=20; expires=" + 过期时间

  上面这一行代码保存了两个cookie信息,有两个expires,每一个expire是前面一个cookie项的过期时间,而不是后面cookie项的过期时间。

  在获取cookie的时候,利用document.cookie不会获取到expires。

 

封装

  可以将上面设置cookie的过程一下,可以封装成一个json格式的类,有添加cookie,获取cookie,删除cookie的功能。

<script>
	cookie = {
		setCookie : function (key, value,expireSeconds){
			var date = new Date();
			date.setSeconds(date.getSeconds() + expireSeconds);
			document.cookie = key + "=" + value + "; expires=" + date;
		},
		getCookie : function (key){
			var items = document.cookie.split("; ");//千万注意是以分号加空格来分割
			for(var i = 0; i < items.length; i++){
				item = items[i].split("=");
				if(item[0] == key){
					return item[1];
				}
			}
		},
		removeCookie : function(key){
			this.setCookie(key,"",-1);
		}
	}
	cookie.setCookie("name","JavaScript",300);//300s过期
	cookie.setCookie("age","30",300);
	alert(cookie.getCookie("name"));//JavaScript
	alert(cookie.getCookie("age"));//30

	cookie.removeCookie("age");
	alert(cookie.getCookie("age"));//空
</script>

  

  

  

posted @ 2017-12-01 16:32  寻觅beyond  阅读(217)  评论(0编辑  收藏  举报
返回顶部