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

<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. GoodReads: Machine Learning (Part 3)

    In the first installment of this series, we scraped reviews from Goodreads. In thesecond one, we per ...

  2. 用超链接传递数组或get方式

    <?php /** * 超链接传递数组参数 */ if($_GET['names']){ $arr=explode('-',$_GET['names']);//将数组分割为字符串 print_r ...

  3. Android WebView 不支持 H5 input type="file" 解决方法

    最近因为赶项目进度,因此将本来要用原生控件实现的界面,自己做了H5并嵌入webview中.发现点击H5中 标签 不能打开android资源管理器. 通过网络搜索发现是因为 android webvie ...

  4. 【小练习02】CSS--网易产品

    要求用css和HTML实现下图效果: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8& ...

  5. nginx四层负载均衡配置

    nginx四层负载均衡配置代理Mysql集群 环境如下: ip 192.168.6.203 Nginx ip 192.168.6.*(多台) Mysql 步骤一 查看Nginx是否安装stream模块 ...

  6. Sql Server 事物

    事物的定义: 数据库的事物是原子性的,原子性的概念是指把一些事情当做一个单元来看待. 从数据库的角度看,它是指全部执行或者全部不执行的一条或者多条语句的最小组合:为了理解事务的概念,需要能够定义非常明 ...

  7. “java.lang.IllegalArgumentException: Failed to evaluate expression ‘ROLE_USER’”报错的解决

    这个问题出现在Spring Security的相关配置中,找到原来的这一行: <security:intercept-url pattern="/**" access=&qu ...

  8. MongoDB--初始

    指定启动目录,以服务形式启动 Mongod --dbpath=XXXXXX --logpath=XXXXXXXX --logappend --serviceName "XXXXX" ...

  9. Swift基础语法

    简介 特点 (1)优于OC,快速,安全 (2)取消了预编译指令包括宏定义(OC用的太多了) (3)取消了OC指针和不安全访问的使用(看不到星星了) (4)舍弃 Objective-C 早期应用 Sma ...

  10. 查找oracle自己用户的表

    查找oracle自己用户的表 select table_name from user_tables;