jquery对cookie进行读取、写入和删除

使用前注意:

cookie虽然是存储在本地,但是是针对服务器的。如果是file:///C:/Users/BYF/Desktop/2.html这种静态网址是无法使用cookie的,只有部署在服务器上的页面才可以使用cookie,类似于http://localhost:8080/test/2.html 这种网址才可以访问

使用前首先需要下载jquery.cookie.js这个文件,下载地址:http://plugins.jquery.com/cookie/

示例代码:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>demo</title>
		<script src="http://code.jquery.com/jquery-1.9.0.min.js"></script>
		<script src="jquery.cookie.js"></script>
		<script>
		$(function() { 
			 if($.cookie("o") == null) { 
			   varo = { name: "张三", age: 24 }; 
			   varstr = JSON.stringify(varo);  //对序列化成字符串然后存入cookie
			   $.cookie("o", varstr, { 
				 expires:7 //设置时间,如果此处留空,则浏览器关闭此cookie就失效。
			   });
			   alert("cookie为空");
			 }
			 else{ 
			   varstr1 = $.cookie("o");
			   varo1 = JSON.parse(varstr1);  //字符反序列化成对象
			   alert(varo1.name+","+varo1.age);        //输反序列化出来的对象的姓名值
			 }
		})
		</script>
	</head>
	<body>
		
	</body>
</html>

说明文档:

1.新添加一个会话 cookie: 

$.cookie('the_cookie', 'the_value'); 

注:当没有指明 cookie有效时间时,所创建的cookie有效期默认到用户关闭浏览器为止,所以被称为 

“会话cookie(session cookie)”。 

2.创建一个cookie并设置有效时间为 7天: 

$.cookie('the_cookie', 'the_value', { expires: 7 }); 

注:当指明了cookie有效时间时,所创建的cookie被称为“持久 cookie (persistent cookie)”。 

3.创建一个cookie并设置 cookie的有效路径: 

$.cookie('the_cookie', 'the_value', { expires: 7, path: '/' }); 

注:在默认情况下,只有设置 cookie的网页才能读取该 cookie。如果想让一个页面读取另一个页面设 置的cookie,必须设置cookie的路径。cookie的路径用于设置能够读取 cookie的顶级目录。将这 个路径设置为网站的根目录,可以让所有网页都能互相读取 cookie 。 

4.读取cookie: 

$.cookie('the_cookie'); // cookie存在 => 'the_value' 

$.cookie('not_existing'); // cookie不存在 => null 

5.删除cookie,通过传递null作为cookie的值即可: 

$.cookie('the_cookie', null); 

----------相关参数的解释--------------- 

1).expires: 365 

定义cookie的有效时间,值可以是一个数字(从创建cookie时算起,以天为单位)或一个Date 对 

象。如果省略,那么创建的cookie是会话cookie,将在用户退出浏览器时被删除。 

2).path: '/' 

默认情况:只有设置cookie的网页才能读取该cookie。 

定义cookie的有效路径。默认情况下, 该参数的值为创建 cookie 的网页所在路径(标准浏览器的行为) 。 

如果你想在整个网站中访问这个cookie需要这样设置有效路径:path: '/'。如果你想删除一个定义 

了有效路径的 cookie,你需要在调用函数时包含这个路径:$.cookie('the_cookie', null, 

{ path: '/' });。 domain: 'example.com' 

默认值:创建 cookie的网页所拥有的域名。 

3).secure: true 

默认值:false。如果为true,cookie的传输需要使用安全协议(HTTPS)。 

4).raw: true 

默认值:false。 

默认情况下,读取和写入 cookie 的时候自动进行编码和解码(使用encodeURIComponent 编码, 

decodeURIComponent 解码)。要关闭这个功能设置 raw: true 即可。

猜你喜欢

转载自blog.csdn.net/qq_36470686/article/details/83544980