JavaScript一个cookie存储的类
所有输出都在浏览器的控制台中
<script type="text/javascript">
/**
* cookieStorage.js
* 本类实现像localStorage和sessionStorage一样存储API,不同的是,基于http cookie实现它
*/
function cookieStorage( maxage , path ){ //两个参数分别代表存储有效期和作用域
//获取一个存储全部cookie信息的对象
this.cookie = (function(){
var cookie = { }; //该对象最终会返回
var all = document.cookie; //以大字符串的形式获取所有cookie信息
if( all == "") //如果该属性为空字符串
return cookie; //返回一个空对象
var list = all.split("; "); //分离出名/值对
for(var i = 0 ; i < list.length ; i++){
var cookie = list[i];
var p = cookie.indexOf("="); //查找第一个“=”符号
var name = cookie.substring(0 , p);//获取cookie名字
var value = cookie.substring(p+1); //获取cookie对应的值
value = decodeURIComponent(value); //对其进行解码
cookie[name] = value ; //将名值对存储到对象中
}
return this;
}()); //将所有cookie的名字存储到一个数组中
this.keys = [];
for( var key in this.cookie)
key.push(key); //现在定义存储API公共的属性和方法
//存储的cookie的个数
this.length = this.keys.length; //返回n个cookie的名字,如果n越界则返回null
this.key = function(n){
if( n < 0 || n >= this.keys.length )
return null;
return this.keys[n];
}; //返回指定名字的cookie值,如果不存在则返回null
this.getItem = function(name){
return this.cookie[name] || null;
}; //存储cookie值
this.setItem = function(key,value){
if (!(key in this.cookie)) {
this.keys.push(key);
this.length++;
} //将该名/值对数据存储到cookie对象中
this.cookie[key] = value; //开始正式设置cookie
//首先将要存储的cookie的值进行编码,同时创建一个“名字=编码后的值”形式的字符串
var cookie = key+"="+encodeURIComponent(value); //将cookie的属性也加入到该字符串中
if( maxage )
cookie += "; max-age="+maxage;
if( path )
cookie += "; path="+path; //通过document.cookie的属性来设置cookie
document.cookie = cookie;
}; //删除指定的cookie
this.removeItem = function(key){
if( !(key in this.cookie))
return ; //如果cookie不存在,则什么也不做
//从内部维护的cookie组删除指定的cookie
delete this.cookie[key]; //同时将cookie中的名字也在内部的数组中删除
//如果使用ES5定义的数组 indexOf()方法会更加简单
for(var i = 0 ; i < this.keys.length ; i++){ //遍历所有的名字
if(this.keys[i]===key){ //当找到要找的那个
this.keys.splice(i,1); //将它从数组中删除
break;
}
}
this.length--; //cookie个数减一 //最终通过该cookie值设置为空字符串以及将有效期设置为0来删除指定的cookie
document.cookie = key + "=; max-age=0";
}; //删除所有的cookie
this.clear = function(){
//循环所有的cookie的名字,并将cookie删除
for(var i = 0 ; i < this.keys.length ; i++)
document.cookie = this.keys[i]+"=; max-age=0"; //重置所有内部状态
this.cookie = {};
this.keys = [];
this.length = 0;
};
} var ck = new cookieStorage(3600,"/");
ck.setItem("a","value");
ck.setItem("b","value2");
ck.setItem("c","value3");
console.log(ck.getItem("a"));
ck.removeItem("a");
if(ck.getItem("a"))
console.log(ck.getItem("a"));
else
console.log("已经被删除")
console.log(ck.getItem("b"));
ck.clear();
if(ck.getItem("c"))
console.log(ck.getItem("c"));
else
console.log("del"); </script>
JavaScript一个cookie存储的类的更多相关文章
- JavaScript一个集合的运算类
输出都在控制台中: <script type="text/javascript"> function Set() { //这是一个构造函数 this.values = ...
- ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 用javascript在客户端删除某一个cookie键值对 input点击链接另一个页面,各种操作。 C# 往线程里传参数的方法总结 TCP/IP 协议 用C#+Selenium+ChromeDriver 生成我的咕咚跑步路线地图 (转)值得学习百度开源70+项目
ASP.NET MVC WebApi 返回数据类型序列化控制(json,xml) 我们都知道在使用WebApi的时候Controller会自动将Action的返回值自动进行各种序列化处理(序列化为 ...
- 用javascript在客户端删除某一个cookie键值对
下面这个方法展示如何在客户端浏览器上用javascript删除某一个cookie键值对. //用javascript删除某一个cookie的方法,该方法传入要删除cookie的名称 function ...
- [转]javascript js cookie的存储,获取和删除
本文转自:http://www.jb51.net/article/13240.htm 使用方法: //1.存储Cookie //2.参数说明: 1.参数1:Cookie存储Name,参数2:Cooki ...
- asp(utf-8) set cookie 用 javascript 读cookie发现一个问题
asp: <%setCookie("user_id","test")%> //传一个cookie ,名: user_id 值:test java ...
- java与javascript对cookie操作的工具类
Java对cookie的操作 package cn.utils; import java.util.HashMap; import java.util.Map; import javax.servle ...
- JavaScript 操作 Cookie
转自作者:聂微东出处:http://www.cnblogs.com/Darren_code/ 什么是 Cookie “cookie 是存储于访问者的计算机中的变量.每当同一台计算机通过浏览器 ...
- JavaScript之Cookie讲解
什么是 Cookie “cookie 是存储于访问者的计算机中的变量.每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cookie.你可以使用 JavaScript 来创建和取回 cookie ...
- Cookie介绍及JavaScript操作Cookie方法详解
本文主要为大家简单介绍了以下Cookie的用途.运行机制,以及JavaScript操作Cookie的各种方法,总结的比较全面,希望能给大家带来帮助. 什么是 Cookie “cookie 是存储于访问 ...
随机推荐
- 刨根究底字符编码之七——ANSI编码与代码页(Code Page)
ANSI编码与代码页(Code Page) 一.ANSI编码 1. 如前所述,在全世界所有国家和民族的文字符号统一编码的Unicode编码方案问世之前,各个国家.民族为了用计算机记录并显示自己的字符, ...
- VR全景:电商巨头的角逐
VR全景智慧城市:京东推"京东梦"挑战淘宝Buy+ ,VR购物谁主沉浮? VR全景智慧城市是国内首家商业全景平台,结合先进VR虚拟现实技术,以线下实体为依托,将空间还原到线上,用户 ...
- 基于java.util.logging实现轻量级日志记录库(增加根据当前类class初始化,修复线程池模型(javaEE)下的堆栈轨迹顺序与当前调用方法不一致问题)
前言: 本章介绍自己写的基于java.util.logging的轻量级日志记录库(baseLog). 该版本的日志记录库犹如其名,baseLog,是个实现日志记录基本功能的小库,适合小型项目使用,方便 ...
- 给Linux系统/网络管理员准备的Nmap命令的29个实用范例
我将用两个不同的部分来涵盖大部分NMAP的使用方法,这是nmap关键的第一部分.在下面的设置中,我使用两台已关闭防火墙的服务器来测试Nmap命令的工作情况. 192.168.0.100 – serve ...
- Hybrid App开发之jQuery基础
前言: 前面学习了JavaScript/Html/Css的基础知识,今天学习一下常用js框架jQuery的使用进行快速的开发. JQuery的基本功能: 方位和操作DOM元素 控制页面样式 对页面事件 ...
- ActiveMQ 和消息简介
Apache ActiveMQ 是远程系统间进行通信的消息代理,实现了 JMS(Java Message Service,Java 消息服务).尽管 ActiveMQ 是使用 Java 写的,但是其提 ...
- css让文字在一行内显示
1.例如 p元素,里面的文字不换行显示,超出部分不隐藏 p{ width:100px; word-break:keep-all; white-space:nowrap; } 2.例如 p元素,里面的文 ...
- SQLServer数据库操作
--创建数据库create database 在线考试系统on(name=在线考试系统_DATA,filename='E:\DB\在线考试系统_DATA.mdf',size=5mb,maxsize=2 ...
- AngularJS高级程序设计读书笔记 -- 指令篇 之 内置指令
1. 内置指令(10-12 章) AngularJS 内置超过 50 个内置指令, 包括 数据绑定,表单验证,模板生成,时间处理 和 HTML 操作. 指令暴露了 AngularJS 的核心功能, 如 ...
- Scheme实现二叉查找树及基本操作(添加、删除、并、交)
表转化成平衡二叉树 其中有一种分治的思想. (define (list->tree elements) (define (partial-tree elts n) (if (= n 0) (co ...