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>
JavaScript中的cookie的更多相关文章
- Javascript中关于cookie的那些事儿
Javascript-cookie 什么是cookie? 指某些网站为了辨别用户身份.进行session跟踪而储存在用户本地终端上的数据(通常经过加密).简单点来说就是:浏览器缓存. cookie由什 ...
- JavaScript中的Cookie 和 Json的使用
JavaScript中的Cookie 和 Json的使用 JSON JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.采用的是完全独立于编程语言的文本格式来存 ...
- javascript中的cookie,以及事件解析
Cookie: 它的意思是在本地的客户端的磁盘上以很小的文件形式保存数据,Cookie的处理原则上需要在服务器环境下运行,目前Chrome不可以在客户端操作Cookie,其他浏览器均可以, Coo ...
- JavaScript中document.cookie
“某些 Web 站点在您的硬盘上用很小的文本文件存储了一些信息,这些文件就称为 Cookie.”—— MSIE 帮助.一般来说,Cookies 是 CGI 或类似,比 HTML 高级的文件.程序等创建 ...
- JavaScript中设置cookie的值
cookie 与 session 是网页开发中常用的信息存储方式.Cookie是在客户端开辟的一块可存储用户信息的地方:Session是在服务器内存中开辟的一块存储用户信息的地方.JavaScript ...
- 浅谈JavaScript中的cookie
什么是cookie?简单来说,cookie就是网站服务器存放在我们计算机上的一小段(一般大小不超过4KB)用来识别和记录用户的个人信息的文本.HTTP协议是一种没有“状态”的传输协议,也就是说,服务器 ...
- 1、JavaScript中的Cookie 用于存储 web 页面的用户信息。
总结:每个浏览器都有一定数量限制的cookie.每个浏览器中,每一个cookie都有一个path路径,指向请求访问的网页. -------------------------------------- ...
- javascript中的 cookie对象
Cookie 对象 是一种以文件(Cookie文件)的形式保存在客户端硬盘的Cookies文件夹中的数据信息(Cookie数据).Cookie文件夹中的用户数据信息(Cookie数据).Cookie文 ...
- Javascript中的Cookie操作
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
随机推荐
- sahrepoint 上传到文档库
sharepoint学习笔记汇总 http://blog.csdn.net/qq873113580/article/details/20390149 /// <summary&g ...
- 转载 .Net多线程编程—任务Task https://www.cnblogs.com/hdwgxz/p/6258014.html
.Net多线程编程—任务Task 1 System.Threading.Tasks.Task简介 一个Task表示一个异步操作,Task的创建和执行是独立的. 只读属性: 返回值 名称 说明 ob ...
- sed插入,替换指定行的特定字符串,删除指定行首的#
sed -i '$a service snmpd start' /etc/rc.local sed -i "41s:public:mykey:g" /etc/snmp/snmpd. ...
- Qt warning: 构建目录必须和源文件目录为同级目录
从一台电脑转移项目到另一电脑, 路径发生变化,重新构建运行时会出现“QT 构建目录必须和源目录为同级目录”提示,解决办法很加单.如下: 方法一: 点击 project(项目)->然后,看看Bui ...
- Swift 重点知识汇总
1.语句末尾的分号可有可无,类似python和JavaScript. print("hello world!") 2.let定义常量,var定义变量 let aConstant = ...
- 看think in java 随笔
java的方法是运行期动态绑定上去的,可以根据自己真正实例化的类来判断调用哪个方法,比如子类重写了父类方法,会调用子类方法. 而利用final关键字可以让方法不能重写,就可以在编译期就绑定,这样就可以 ...
- python 日志
logger.conf 配置文件 #logger.conf ############################################### [loggers] keys=root,ex ...
- Iterable接口
Iterable接口 总览 这个接口用来表明可以进行迭代.具体的迭代方式,可以通过iterator()方法获取到一个迭代器,在迭代器中会实现如何获取下一个元素,以及是否迭代结束. java8中源码如下 ...
- Linux性能评测工具之一:gprof篇
这些天自己试着对项目作一些压力测试和性能优化,也对用过的测试工具作一些总结,并把相关的资料作一个汇总,以便以后信手拈来! 1 简介 改进应用程序的性能是一项非常耗时耗力的工作,但是究竟程序中是哪些函数 ...
- 【SQL】四种排序开窗函数
一 .简单了解什么是开窗函数 什么是开窗函数,开窗函数有什么作用,特征是什么? 所谓开窗函数就是定义一个行为列,简单讲,就是在你查询的结果上,直接多出一列值(可以是聚合值或是排序号),特征就是带有ov ...