所有输出都在浏览器的控制台中

<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存储的类的更多相关文章

  1. JavaScript一个集合的运算类

    输出都在控制台中: <script type="text/javascript"> function Set() { //这是一个构造函数 this.values = ...

  2. 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的返回值自动进行各种序列化处理(序列化为 ...

  3. 用javascript在客户端删除某一个cookie键值对

    下面这个方法展示如何在客户端浏览器上用javascript删除某一个cookie键值对. //用javascript删除某一个cookie的方法,该方法传入要删除cookie的名称 function ...

  4. [转]javascript js cookie的存储,获取和删除

    本文转自:http://www.jb51.net/article/13240.htm 使用方法: //1.存储Cookie //2.参数说明: 1.参数1:Cookie存储Name,参数2:Cooki ...

  5. asp(utf-8) set cookie 用 javascript 读cookie发现一个问题

    asp: <%setCookie("user_id","test")%>   //传一个cookie ,名: user_id 值:test java ...

  6. java与javascript对cookie操作的工具类

    Java对cookie的操作 package cn.utils; import java.util.HashMap; import java.util.Map; import javax.servle ...

  7. JavaScript 操作 Cookie

    转自作者:聂微东出处:http://www.cnblogs.com/Darren_code/      什么是 Cookie “cookie 是存储于访问者的计算机中的变量.每当同一台计算机通过浏览器 ...

  8. JavaScript之Cookie讲解

    什么是 Cookie “cookie 是存储于访问者的计算机中的变量.每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cookie.你可以使用 JavaScript 来创建和取回 cookie ...

  9. Cookie介绍及JavaScript操作Cookie方法详解

    本文主要为大家简单介绍了以下Cookie的用途.运行机制,以及JavaScript操作Cookie的各种方法,总结的比较全面,希望能给大家带来帮助. 什么是 Cookie “cookie 是存储于访问 ...

随机推荐

  1. python unittest 测试笔记(二):使用Requests

    1. Requests 唯一的一个非转基因的 Python HTTP 库,人类可以安全享用.[Python Requests快速入门 :]http://cn.python-requests.org/z ...

  2. 构建自己的PHP框架--构建模版引擎(2)

    自从来到新公司就一直很忙,最近这段时间终于稍微闲了一点,赶紧接着写这个系列,感觉再不写就烂尾了. 之前我们说到,拿到{{ $name }}这样一段内容时,我们只需要将它转化成<?php echo ...

  3. cpp(第十三章)

    1.动态(晚期)联编需要显示定义复制构造函数,赋值运算符,虚构函数. 2.纯虚类不能声明对象. 3.赋值运算符的特征标随类而异. 4.返回类型协变,重新定义继承的方法,应确保与原来的原型完全相同,但如 ...

  4. java环境变量最佳配置

    1.打开我的电脑--属性--高级--环境变量  2.新建系统变量JAVA_HOME 和CLASSPATH 变量名:JAVA_HOME 变量值:C:\Program Files\Java\jdk1.7. ...

  5. 谈谈this对象

    通过平常的使用简单总结了一下不同形式的函数调用下this的指向,函数的调用形式决定了this的指向.就简单分析一下以下几种情况: 情况一:纯粹的函数调用 eg: var x=1; function f ...

  6. git rebase -i命令修改commit历史

    [TOC] 修改commit历史的前提 修改历史的提交是可能有风险的,是否有风险取决于commit是否已经推送远程分支,未推送,无风险,如果已推送,就千万不要修改commit了. 修改commit历史 ...

  7. 抓包工具 - Fiddler(详细介绍)

    Fiddler的详细介绍 一.Fiddler与其他抓包工具的区别 1.Firebug虽然可以抓包,但是对于分析http请求的详细信息,不够强大.模拟http请求的功能也不够,且firebug常常是需要 ...

  8. navicat连接oracle 报 ORA-12737 set CHS16GBK

    1首先,我们打开“工具”-->"选项"菜单,见到如下界面,依据OCI library(oci.dll) 路径,导航到 navicat oci 目录下,备份里面的文件(通过在该 ...

  9. JavaScript设计模式_10_职责链模式

    职责链模式的定义是:使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系,将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止.职责链模式的名字非常形象,一系列可能 ...

  10. 《HelloGitHub》第 15 期

    公告 这段时间没怎么写文章,跑去写 https://hellogithub.com 这个网站了,现在已经顺利上线,功能后面会持续迭代. 最后,这个 https://hellogithub.com 网站 ...