关于document.cookie的使用javascript


Posted in Javascript onApril 11, 2008

document.cookie="userId=828";
如果要一次存储多个名/值对,可以使用分号加空格(; )隔开,例如:
document.cookie="userId=828; userName=hulk";
在cookie的名或值中不能使用分号(;)、逗号(,)、等号(=)以及空格。在cookie的名中做

到这点很容易,但要保存的值是不确定的。如何来存储这些值呢?方法是用escape()函数进行编

码,它能将一些特殊符号使用十六进制表示,例如空格将会编码为“20%”,从而可以存储于

cookie值中,而且使用此种方案还可以避免中文乱码的出现。例如:
document.cookie="str="+escape("I love ajax");
相当于:
document.cookie="str=I%20love%20ajax";
当使用escape()编码后,在取出值以后需要使用unescape()进行解码才能得到原来的cookie值,

这在前面已经介绍过。
尽管document.cookie看上去就像一个属性,可以赋不同的值。但它和一般的属性不一样,改变

它的赋值并不意味着丢失原来的值,例如连续执行下面两条语句:
document.cookie="userId=828";
document.cookie="userName=hulk";
这时浏览器将维护两个cookie,分别是userId和userName,因此给document.cookie赋值更像执

行类似这样的语句:
document.addCookie("userId=828");
document.addCookie("userName=hulk");
事实上,浏览器就是按照这样的方式来设置cookie的,如果要改变一个cookie的值,只需重新赋

值,例如:
document.cookie="userId=929";
这样就将名为userId的cookie值设置为了929。

获取cookie的值
下面介绍如何获取cookie的值。cookie的值可以由document.cookie直接获得:
var strCookie=document.cookie;
这将获得以分号隔开的多个名/值对所组成的字符串,这些名/值对包括了该域名下的所有cookie

。例如:

图7.1显示了输出的cookie值。由此可见,只能够一次获取所有的cookie值,而不能指定cookie

名称来获得指定的值,这正是处理cookie值最麻烦的一部分。用户必须自己分析这个字符串,来

获取指定的cookie值,例如,要获取userId的值,可以这样实现:

这样就得到了单个cookie的值

用类似的方法,可以获取一个或多个cookie的值,其主要的技巧仍然是字符串和数组的相关操作。

给cookie设置终止日期
到现在为止,所有的cookie都是单会话cookie,即浏览器关闭后这些cookie将会丢失,事实上这

些cookie仅仅是存储在内存中,而没有建立相应的硬盘文件。
在实际开发中,cookie常常需要长期保存,例如保存用户登录的状态。这可以用下面的选项来实

现:
document.cookie="userId=828; expires=GMT_String";
其中GMT_String是以GMT格式表示的时间字符串,这条语句就是将userId这个cookie设置为

GMT_String表示的过期时间,超过这个时间,cookie将消失,不可访问。例如:如果要将cookie

设置为10天后过期,可以这样实现:

删除cookie
为了删除一个cookie,可以将其过期时间设定为一个过去的时间,例如:

指定可访问cookie的路径
默认情况下,如果在某个页面创建了一个cookie,那么该页面所在目录中的其他页面也可以访问

该cookie。如果这个目录下还有子目录,则在子目录中也可以访问。例如在

www.xxxx.com/html/a.html中所创建的cookie,可以被www.xxxx.com/html/b.html或

www.xxx.com/ html/ some/c.html所访问,但不能被www.xxxx.com/d.html访问。
为了控制cookie可以访问的目录,需要使用path参数设置cookie,语法如下:
document.cookie="name=value; path=cookieDir";
其中cookieDir表示可访问cookie的目录。例如:
document.cookie="userId=320; path=/shop";
就表示当前cookie仅能在shop目录下使用。
如果要使cookie在整个网站下可用,可以将cookie_dir指定为根目录,例如:
document.cookie="userId=320; path=/";

指定可访问cookie的主机名
和路径类似,主机名是指同一个域下的不同主机,例如:www.google.com和gmail.google.com就

是两个不同的主机名。默认情况下,一个主机中创建的cookie在另一个主机下是不能被访问的,

但可以通过domain参数来实现对其的控制,其语法格式为:
document.cookie="name=value; domain=cookieDomain";
以google为例,要实现跨主机访问,可以写为:
document.cookie="name=value;domain=.google.com";
这样,所有google.com下的主机都可以访问该cookie。

综合示例:构造通用的cookie处理函数
cookie的处理过程比较复杂,并具有一定的相似性。因此可以定义几个函数来完成cookie的通用

操作,从而实现代码的复用。下面列出了常用的cookie操作及其函数实现。
1.添加一个cookie:addCookie(name,value,expiresHours)
该函数接收3个参数:cookie名称,cookie值,以及在多少小时后过期。这里约定expiresHours为

0时不设定过期时间,即当浏览器关闭时cookie自动消失。该函数实现如下:

2.获取指定名称的cookie值:getCookie(name)
该函数返回名称为name的cookie值,如果不存在则返回空,其实现如下:

3.删除指定名称的cookie:deleteCookie(name)
该函数可以删除指定名称的cookie

Javascript 相关文章推荐
20款效果非常棒的 jQuery 插件小结分享
Nov 18 Javascript
jquery右下角弹出提示框示例代码
Oct 08 Javascript
jQuery调用RESTful WCF示例代码(GET方法/POST方法)
Jan 26 Javascript
使用Node.js配合Nginx实现高负载网络
Jun 28 Javascript
JavaScript使用Range调色及透明度实例
Sep 25 Javascript
浅谈Javascript中的Label语句
Dec 14 Javascript
js 公式编辑器 - 自定义匹配规则 - 带提示下拉框 - 动态获取光标像素坐标
Jan 04 Javascript
对vue v-if v-else-if v-else 的简单使用详解
Sep 29 Javascript
node.js爬取中关村的在线电瓶车信息
Nov 13 Javascript
Moment.js实现多个同时倒计时
Aug 26 Javascript
js校验开始时间和结束时间
May 26 Javascript
Vue element-ui父组件控制子组件的表单校验操作
Jul 17 Javascript
javascript比较文档位置
Apr 08 #Javascript
js函数般调用正则
Apr 08 #Javascript
javascript背投广告代码的完善
Apr 08 #Javascript
大家未必知道的Js技巧收藏
Apr 07 #Javascript
用JavaScript调用WebService的示例
Apr 07 #Javascript
HTML中Select不用Disabled实现ReadOnly的效果
Apr 07 #Javascript
javascript add event remove event
Apr 07 #Javascript
You might like
php数组函数序列之rsort() - 对数组的元素值进行降序排序
2011/11/02 PHP
PHP使用DES进行加密与解密的方法详解
2013/06/06 PHP
php简单实现无限分类树形列表的方法
2015/03/27 PHP
php+flash+jQuery多图片上传源码分享
2020/07/27 PHP
javascript 对象的定义方法
2007/01/10 Javascript
新手入门常用代码集锦
2007/01/11 Javascript
JavaScript函数、方法、对象代码
2008/10/29 Javascript
Javascript面象对象成员、共享成员变量实验
2010/11/19 Javascript
JS对select控件option选项的增删改查示例代码
2013/10/21 Javascript
JS+CSS实现简易实用的滑动门菜单效果
2015/09/18 Javascript
JavaScript下的时间格式处理函数Date.prototype.format
2016/01/27 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
2016/05/09 Javascript
javascript判断图片是否加载完成的方法推荐
2016/05/13 Javascript
jQuery实现每隔几条元素增加1条线的方法
2016/06/27 Javascript
使用JS 插件qrcode.js生成二维码功能
2017/02/20 Javascript
angular json对象push到数组中的方法
2018/02/27 Javascript
layui 给数据表格加序号的方法
2018/08/20 Javascript
vue实现匀速轮播效果
2020/06/29 Javascript
[01:20]2018DOTA2亚洲邀请赛总决赛战队LGD晋级之路
2018/04/07 DOTA
Python线性回归实战分析
2018/02/01 Python
对DataFrame数据中的重复行,利用groupby累加合并的方法详解
2019/01/30 Python
Python利用PyExecJS库执行JS函数的案例分析
2019/12/18 Python
如何通过Python实现RabbitMQ延迟队列
2020/11/28 Python
Html5应用程序缓存(Cache manifest)
2018/06/04 HTML / CSS
最耐用行李箱,一箱永流传:Briggs & Riley(全球终身保修)
2017/12/07 全球购物
Craghoppers德国官网:户外和旅行服装
2020/02/14 全球购物
销售总监工作职责
2013/11/21 职场文书
大学生村官典型材料
2014/01/12 职场文书
家居装修公司创业计划书范文
2014/03/20 职场文书
学校清明节活动总结
2014/07/04 职场文书
竞选班干部演讲稿300字
2014/08/20 职场文书
环境卫生工作汇报材料
2014/10/28 职场文书
2015年学校教育教学工作总结
2015/04/22 职场文书
倡议书范文大全
2015/04/28 职场文书
开业庆典嘉宾致辞
2015/08/01 职场文书
PHP实现创建以太坊钱包转账等功能
2021/04/21 PHP