javascript cookie用法基础教程(概念,设置,读取及删除)


Posted in Javascript onSeptember 20, 2016

本文实例讲述了javascript cookie用法。分享给大家供大家参考,具体如下:

一、什么是 cookie?

cookie 就是页面用来保存信息,比如自动登录、记住用户名等等。

二、cookie 的特点

同个网站中所有的页面共享一套 cookie

cookie 有数量、大小限制

cookie 有过期时间

三、如何使用 cookie?

通过 document.cookie 来写入 cookie

<!DOCTYPE HTML>
<html lang="en-US">
<head>
 <meta charset="UTF-8">
 <title>cookie基础</title>
</head>
<body>
</body>
</html>
<script type="text/javascript">
document.cookie = 'username=abc';
document.cookie = 'password=123';
document.cookie = 'email=abcdef@123.com';
</script>

打开浏览器查看 cookie,可以发现新定义的 cookie 并不会将原来的覆盖。

如果没有设置过期时间,那么关闭浏览器就会清空 cookie。如何设置过期时间呢?答案是:expires。一般我们会结合 Date 对象来使用。

var d = new Date();
d.setTime(d.getTime() + 1 * 3600 * 1000);
document.cookie = 'username=abc; expires=' + d.toGMTString();

我们可以通过火狐浏览器看到,username 的过期时间是当前时间的 1 小时后。

最后对获取 cookie 的方法进行封装:

function setCookie(name,value,hours){ 
 var d = new Date();
 d.setTime(d.getTime() + hours * 3600 * 1000);
 document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}

学会了如何设置 cookie,那么该如何读取 cookie 呢?

首先我们看下 cookie 里的内容是什么类型?

document.cookie = 'username=abc';
document.cookie = 'password=123';
document.cookie = 'email=abcdef@123.com';
typeof document.cookie; //string
alert(document.cookie); //'username=abc; password=123; email=abcdef@123.com'

得到的是一串字符串,需要注意的是,每个 ; 后面都有个空格。

那么我们如何取到具体的数值呢?附上代码:

function getCookie(name){ 
 var arr = document.cookie.split('; ');
 for(var i = 0; i < arr.length; i++){
 var temp = arr[i].split('=');
 if(temp[0] == name){
  return temp[1];
 }
 }
 return '';
}

除了设置、获取 cookie,我们还可以删除 cookie。我们在网上经常看到有清除用户名这样的功能,其实就是用到了清除 cookie。

清除 cookie 其实很简单,只要使过期时间为过去时间就可以了。

function removeCookie(name){
 var d = new Date();
 d.setTime(d.getTime() - 10000);
 document.cookie = name + '=1; expires=' + d.toGMTString();
}

最后我们将设置、获取、清除 cookie 封装成一个 cookie.js

function setCookie(name,value,hours){ 
 var d = new Date();
 d.setTime(d.getTime() + hours * 3600 * 1000);
 document.cookie = name + '=' + value + '; expires=' + d.toGMTString();
}
function getCookie(name){ 
 var arr = document.cookie.split('; ');
 for(var i = 0; i < arr.length; i++){
 var temp = arr[i].split('=');
 if(temp[0] == name){
  return temp[1];
 }
 }
 return '';
}
function removeCookie(name){
 var d = new Date();
 d.setTime(d.getTime() - 10000);
 document.cookie = name + '=1; expires=' + d.toGMTString();
}

附:这里再补充一个关于cookie的基础应用:javascript cookie记录用户名

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
Javascript中获取出错代码所在文件及行数的代码
Sep 23 Javascript
jquery之超简单的div显示和隐藏特效demo(分享)
Jul 09 Javascript
动态加载script文件的两种方法
Aug 15 Javascript
DropDownList实现可输入可选择(两种版本可选)
Dec 07 Javascript
EditPlus 正则表达式 实战(3)
Dec 15 Javascript
Angular 4 指令快速入门教程
Jun 07 Javascript
ES6中的Promise代码详解
Oct 09 Javascript
JS小球抛物线轨迹运动的两种实现方法详解
Dec 20 Javascript
Vue-router 中hash模式和history模式的区别
Jul 24 Javascript
vue中多个倒计时实现代码实例
Mar 27 Javascript
JS实现可用滑块滑动的缓动图代码
Sep 01 Javascript
vuex actions异步修改状态的实例详解
Nov 06 Javascript
谈谈对JavaScript原生拖放的深入理解
Sep 20 #Javascript
Javascript获取图片原始宽度和高度的方法详解
Sep 20 #Javascript
AngularJS 过滤器(自带和自建)详解
Sep 19 #Javascript
js Canvas实现圆形时钟教程
Sep 19 #Javascript
Bootstrap模态框调用功能实现方法
Sep 19 #Javascript
javascript实现的上下无缝滚动效果
Sep 19 #Javascript
Angular ng-class详解及实例代码
Sep 19 #Javascript
You might like
php中利用str_pad函数生成数字递增形式的产品编号
2013/09/30 PHP
PHP分页类集锦
2014/11/18 PHP
php中ob_get_length缓冲与获取缓冲长度实例
2014/11/20 PHP
javascript web页面刷新的方法收集
2009/07/02 Javascript
Node.js抓取中文网页乱码问题和解决方法
2015/02/10 Javascript
jQuery ui实现动感的圆角渐变网站导航菜单效果代码
2015/08/26 Javascript
jquery UI Datepicker时间控件的使用方法(终结版)
2015/11/07 Javascript
Bootstrap基本插件学习笔记之折叠(22)
2016/12/08 Javascript
bootstrap 模态框(modal)实现水平垂直居中显示
2017/01/23 Javascript
jQuery插件zTree实现获取一级节点数据的方法
2017/03/08 Javascript
微信小程序 在线支付功能的实现
2017/03/14 Javascript
vue富文本框(插入文本、图片、视频)的使用及问题小结
2018/08/17 Javascript
对angularJs中自定义指令replace的属性详解
2018/10/09 Javascript
原生JavaScript写出Tabs标签页的实例代码
2020/07/20 Javascript
解决在Vue中使用axios POST请求变成OPTIONS的问题
2020/08/14 Javascript
[10:18]2018DOTA2国际邀请赛寻真——找回自信的TNCPredator
2018/08/13 DOTA
Python中的__new__与__init__魔术方法理解笔记
2014/11/08 Python
用Python实现斐波那契(Fibonacci)函数
2016/03/25 Python
Ubuntu 下 vim 搭建python 环境 配置
2017/06/12 Python
python监控linux内存并写入mongodb(推荐)
2017/09/11 Python
图文详解Django使用Pycharm连接MySQL数据库
2019/08/09 Python
python 怎样将dataframe中的字符串日期转化为日期的方法
2019/09/26 Python
linux 下python多线程递归复制文件夹及文件夹中的文件
2020/01/02 Python
python全栈开发语法总结
2020/11/22 Python
伊芙丽官方旗舰店:中国淑女一线品牌
2017/12/01 全球购物
Blancsom美国/加拿大:服装和生活用品供应商
2018/07/27 全球购物
西雅图的买手店:Totokaelo
2019/10/19 全球购物
印度第一网上礼品店:IGP.com
2020/02/06 全球购物
简述你对Statement,PreparedStatement,CallableStatement的理解
2013/03/25 面试题
春节晚会主持词
2014/03/24 职场文书
项目经理任命书范本
2014/06/05 职场文书
会计师事务所实习证明
2014/11/16 职场文书
资料员岗位职责范本
2015/04/13 职场文书
2015年机关党建工作总结
2015/05/22 职场文书
个人欠条范本
2015/07/03 职场文书
意外事故赔偿协议书
2016/03/22 职场文书