本文实例讲述了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中json操作技巧总结》、《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
下面介绍 BindingX 中涉及到的一些核心概念,它们分别是 表达式 、 事件类型 、 属性变换 。要想使用 BindingX 必须先理解这些概念。 表达式(Expression) 表达式,是由数字、运算符、变量等以能求得数值的有意义排列方法所得的组合。譬如, x\*3+10 就是一个表达式,当x被赋值时,整个表达式就会有一个明确的结果。通过表达式,我们就可以描述一个具体的交互行为,比如我们希望
概述 本书主要讲解的是关于 Java 在分布式系统中的应用。本书的读者假设都具备了 Java 的基础知识。 如果你需要了解有关 Java 基础知识,可以参阅笔者的另外一本开源书《Java 编程要点》。 分布式系统的概念 《分布式系统原理与范型》一书中是这样定义分布式系统的: 分布式系统是若干独立计算机的集合,这些计算机对于用户来说就像是单个相关系统。 这里面包含了2个含义: 硬件独立:计算机机器本
主要内容:1、AOP 基本概念,2、AOP(底层原理),3、AOP(JDK 动态代理),4、AOP(术语),5、AOP操作,6、AOP 操作(AspectJ 注解),7、有多个增强类对同一个方法进行增强,设置增强类优先级,8、AOP 操作(AspectJ 配置文件)1、AOP 基本概念 (1)面向切面编程(方面),利用 AOP 可以对业务逻辑的各个部分进行隔离,从而使得 业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。 (2)通俗描述:不通过修改源代码方式,在主干功能里
主要内容:关于版本控制,本地版本控制系统,集中化的版本控制系统,分布式版本控制系统本章关于开始学习 Git。这篇文章将从介绍有关版本控制工具的一些背景知识开始,然后讲解如何在系统运行 Git,最后是关于如何设置 Git 开始工作。 通过本章的学习,了解为什么 Git 这么流行,为什么要使用 Git 以及应该如何设置以便使用 Git。 关于版本控制 什么是“版本控制”?为什么要关心它呢? 版本控制是一种记录一个或若干文件内容变化,以便将来查阅特定版本修订情况的系统。在本书所展示的
就像 Reducers 中描述的一样,一个 Redux reducer 函数需要具备: 应该有类似 (previousState, action) => newState 特征的函数,函数的类型与 Array.prototype.reduce(reducer, ?initialValue) 这个函数很相似。 应该是"纯"函数,纯函数意味着不能突变(原文 mutate,意指直接修改引用所指向的值)它
前言 前面一个章节我们讲解了 Flux 的功能和用法,但在实务上许多开发者较偏好的是同为 Flux-like 但较为简洁且文件丰富清楚的 Redux 当作状态资料管理的架构。Redux 是由 Dan Abramov 所发起的一个开源的 library,其主要功能如官方首页写着:Redux is a predictable state container for JavaScript apps.,亦