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

<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. Spring Boot 学习(3)

    文 by / 林本托 Tips 做一个终身学习的人. Tips 代码路径:https://github.com/iqcz/Springbootdemo/tree/master/code01/ch3 W ...

  2. 汽车Vin码识别—— 一款二手车行业值得拥有的OCR识别软件

    一.汽车Vin码识别产品描述 汽车Vin码识别系统,主要应用在智能手机IOS与Android两个平台中.前端扫描查询模式,无需联网,只需扫描汽车前挡风玻璃右下角的Vin码(车架号),即可轻松识别出车辆 ...

  3. 分享一款在线less转css的神器

          大多数web开发的程序员都了解和使用过Less, LESS是一门 CSS 预处理语言,它扩充了 CSS 语言,增加了诸如变量.混合(mixin).函数等功能,让 CSS 更易维护.方便制作 ...

  4. C# 类型基础(中)

    前一篇文章中我们讲到了值类型和引用类型的一些区别,那这篇我们将深入的分析一下到底有什么不一样 先总结一下两者的差别: 黄金法则: 1.引用类型总是被分配到托管堆上. 2.值类型总是分配到它声明的地方: ...

  5. OpenGL教程(0)——介绍

    OpenGL介绍 OpenGL,全称Open Graphics Library,是一个用C语言写的图形API.通俗地说,OpenGL用来绘制2D/3D图形.目前OpenGL的运用十分广泛,有许多用Op ...

  6. HashSet集合

    HashSet特点 1.无序,不允许重复(无序指元素顺序与添加顺序不一致,每次遍历出来的位置不是恒久不变的) 2.HashSet通过调用hashCode()和equals方法来剔除重复 3.HashS ...

  7. 并发容器ConcurrentHashMap#put方法解析

    jdk1.7.0_79 HashMap可以说是每个Java程序员用的最多的数据结构之一了,无处不见它的身影.关于HashMap,通常也能说出它不是线程安全的.这篇文章要提到的是在多线程并发环境下的Ha ...

  8. windows7 64bit下mvn命令后提示‘cmd’不是内部或外部命令,也不是可执行程序或批处理文件

    首先,开命令提示符,输入如下命令试试echo %M2_HOME% 回车如果显示的路径和安装路径一致说明配置没问题; 那么出现这个问题的原因可能就是路径问题,可能是你安装了某个软件更改了系统映射路径导致 ...

  9. 同是办公软件,wps和office有什么区别?

    今天完美小编为大家带来的是wps和office有什么区别教程,那么到底有什么区别呢?相信很多朋友都模棱两可,说不出所以然,看看下面的教程,相信你会选择更适合你的那一款软件.一起来看看吧! 1.两者特点 ...

  10. Deep Q-Network 学习笔记(二)—— Q-Learning与神经网络结合使用(有代码实现)

    参考资料: https://morvanzhou.github.io/ 非常感谢莫烦老师的教程 http://mnemstudio.org/path-finding-q-learning-tutori ...