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 ...
随机推荐
- python第四十七课——类属性和函数属性
4.类属性和对象属性 类属性:定义在class内,函数外 对象属性:定义在构造函数的内部 演示:类和对象的关系 --> 生命周期 [注意]类加载早,对象加载晚 --> 晚的可以调用早的,早 ...
- Spark机器学习中ml和mllib中矩阵、向量
1:Spark ML与Spark MLLIB区别? Spark MLlib是面向RDD数据抽象的编程工具类库,现在已经逐渐不再被Spark团队支持,逐渐转向Spark ML库,Spark ML是面向D ...
- CSS3渐变——线性渐变
渐变背景一直以来在Web页面中都是一种常见的视觉元素.但一直以来,Web设计师都是通过图形软件设计这些渐变效果,然后以图片形式或者背景图片的形式运用到页面中.Web页面上实现的效果,仅从页面的视觉效果 ...
- nginx服务器常见错误代码500、501、502、503、504、505
一:500错误 1.500 Internal Server Error 内部服务错误:顾名思义500错误一般是服务器遇到意外情况,而无法完成请求. 2.500出错的可能性: a.编程语言语法错误,we ...
- 转载 c# automapper 使用(一) https://www.cnblogs.com/caoyc/p/6367828.html
一.最简单的用法 有两个类User和UserDto 1 public class User 2 { 3 public int Id { get; set; } 4 public string Name ...
- oracle 查询 归档日志最大值和平均值
select max(ss.size_GB), avg(ss.size_GB) from (select s.*, rownum rn2 from (select a.* ...
- 纯html页面中js如何获得项目路径
js,全称javascript,不过虽然是以java开头,不过与java一点关系都没有. js和java有如下区别: (1)js是浏览器端的语言,而java是服务器端的语言. (2)js是动态语言,j ...
- 在Oracle中执行动态SQL的几种方法
转载:在Oracle中执行动态SQL的几种方法 以下为内容留存: 在Oracle中执行动态SQL的几种方法 在一般的sql操作中,sql语句基本上都是固定的,如:SELECT t.empno,t.en ...
- BZOJ3926 ZJOI2015 诸神眷顾的幻想乡 Trie、广义SAM
传送门 树上的任意一条路径一定会在以某一个叶子节点为根的树上成为一条直上直下的链,而总共只有\(20\)个叶子节点. 于是每一次选所有叶子节点中的一个作为根,形成一个\(Trie\),把\(20\)个 ...
- CF932F Escape Through Leaf 斜率优化、启发式合并
传送门 \(DP\) 设\(f_i\)表示第\(i\)个节点的答案,\(S_i\)表示\(i\)的子节点集合,那么转移方程为\(f_i = \min\limits_{j \in S_i} \{a_i ...