js操作cookie保存浏览记录的方法


Posted in Javascript onDecember 25, 2015

本文实例讲述了js操作cookie保存浏览记录的方法。分享给大家供大家参考,具体如下:

说明:最近做了一个功能,记录用户浏览过的产品页面。我的思路是,客户每次进入产品页面,就自己调用JS把产品信息以json的形式保存到cookie里面。

浏览记录的显示是从cookie里读出来,然后解析成json,生成html元素。因为用户可能会同时打开好几个页面,这几个页面上可能都有浏览记录,为了使即使显示浏览记录,每秒中刷新一次。

要用到2个js文件,history.js,关键的聊天记录保存和读取代码。json.js,对json进行处理。

history.js

var addHistory=function(num,id){
  stringCookie=getCookie('history');
  var stringHistory=""!=stringCookie?stringCookie:"{history:[]}";
  var json=new JSON(stringHistory);
  var e="{num:"+num+",id:"+id+"}";
  json['history'].push(e);//添加一个新的记录
  setCookie('history',json.toString(),30);
}
//显示历史记录
var DisplayHistory=function(){
  var p_ele=document.getElementById('history');
   while (p_ele.firstChild) {
   p_ele.removeChild(p_ele.firstChild);
   }
  var historyJSON=getCookie('history');
  var json=new JSON(historyJSON);
  var displayNum=6;
  for(i=json['history'].length-1;i>0;i--){
    addLi(json['history'][i]['num'],json['history'][i]['id'],"history"); 
    displayNum--;
    if(displayNum==0){break;}
  }
}
//添加一个li元素
var addLi=function(num,id,pid){
  var a=document.createElement('a');
  var href='product.action?pid='+id;
  a.setAttribute('href',href);
  var t=document.createTextNode(num);
  a.appendChild(t);
  var li=document.createElement('li');
  li.appendChild(a);
  document.getElementById(pid).appendChild(li);
}
//添加cookie
var setCookie=function(c_name,value,expiredays)
{
  var exdate=new Date()
  exdate.setDate(exdate.getDate()+expiredays)
  cookieVal=c_name+ "=" +escape(value)+((expiredays==null) ? "" : ";expires="+exdate.toGMTString());
//  alert(cookieVal);
  document.cookie=cookieVal;
}
//获取cookie
function getCookie(c_name)
{
  if (document.cookie.length>0)
   {
   c_start=document.cookie.indexOf(c_name + "=")
   if (c_start!=-1)
    {
    c_start=c_start + c_name.length+1
    c_end=document.cookie.indexOf(";",c_start)
    if (c_end==-1) c_end=document.cookie.length
//    document.write(document.cookie.substring(c_start,c_end)+"<br>");
    return unescape(document.cookie.substring(c_start,c_end))
    }
   }
  return ""
}

json.js

var JSON = function(sJSON){
  this.objType = (typeof sJSON);
  this.self = [];
  (function(s,o){for(var i in o){o.hasOwnProperty(i)&&(s[i]=o[i],s.self[i]=o[i])};})(this,(this.objType=='string')?eval('0,'+sJSON):sJSON);
}
JSON.prototype = {
  toString:function(){
    return this.getString();
  },
  valueOf:function(){
    return this.getString();
  },
  getString:function(){
    var sA = [];
    (function(o){
      var oo = null;
      sA.push('{');
      for(var i in o){
        if(o.hasOwnProperty(i) && i!='prototype'){
          oo = o[i];
          if(oo instanceof Array){
            sA.push(i+':[');
            for(var b in oo){
              if(oo.hasOwnProperty(b) && b!='prototype'){
                sA.push(oo[b]+',');
                if(typeof oo[b]=='object') arguments.callee(oo[b]);
              }
            }
            sA.push('],');
            continue;
          }else{
            sA.push(i+':'+oo+',');
          }
          if(typeof oo=='object') arguments.callee(oo);
        }
      }
      sA.push('},');
    })(this.self);
    return sA.slice(0).join('').replace(/
objectobject
,/ig,'').replace(/,\}/g,'}').replace(/,\]/g,']').slice(0,-1);
  },
  push:function(sName,sValue){
    this.self[sName] = sValue;
    this[sName] = sValue;
  }
}

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
jQuery Ajax之load()方法
Oct 12 Javascript
JavaScript 利用Cookie记录用户登录信息
Dec 08 Javascript
actionscript与javascript的区别
May 25 Javascript
js实现网页倒计时、网站已运行时间功能的代码3例
Apr 14 Javascript
jQuery.lazyload+masonry改良图片瀑布流代码
Jun 20 Javascript
jquery实现submit提交表单
Feb 03 Javascript
JS实现的加减乘除四则运算计算器示例
Aug 09 Javascript
ECMAscript 变量作用域总结概括
Aug 18 Javascript
深入理解vue中slot与slot-scope的具体使用
Jan 26 Javascript
Vue实现table上下移动功能示例
Feb 21 Javascript
js使用cookie实现记住用户名功能示例
Jun 13 Javascript
js实现带搜索功能的下拉框
Jan 11 Javascript
js实现跨域的多种方法
Dec 25 #Javascript
jquery.cookie.js用法实例详解
Dec 25 #Javascript
理解javascript中try...catch...finally
Dec 25 #Javascript
javascript实现简单加载随机色方块
Dec 25 #Javascript
学习JavaScript鼠标响应事件
Dec 25 #Javascript
理解javascript中DOM事件
Dec 25 #Javascript
理解JavaScript中worker事件api
Dec 25 #Javascript
You might like
一个基于phpQuery的php通用采集类分享
2014/04/09 PHP
Yii框架创建cronjob定时任务的方法分析
2017/05/23 PHP
laravel5.1 ajax post 传值_token示例
2019/10/24 PHP
张孝祥JavaScript学习阶段性总结(2)--(X)HTML学习
2007/02/03 Javascript
JavaScript打印iframe内容示例代码
2013/08/20 Javascript
js和css写一个可以自动隐藏的悬浮框
2014/03/05 Javascript
Javascript 绘制 sin 曲线过程附图
2014/08/21 Javascript
angularjs学习笔记之完整的项目结构
2015/09/26 Javascript
JS实现仿腾讯微博无刷新删除微博效果代码
2015/10/16 Javascript
this,this,再次讨论javascript中的this,超全面(经典)
2016/01/05 Javascript
原生JavaScript编写canvas版的连连看游戏
2016/05/29 Javascript
jquery+CSS3实现3D拖拽相册效果
2016/07/18 Javascript
AngularJS API之copy深拷贝详解及实例
2016/09/14 Javascript
基于JavaScript实现屏幕滚动效果
2017/01/18 Javascript
jquery实现弹窗功能(窗口居中显示)
2017/02/27 Javascript
jQuery md5加密插件jQuery.md5.js用法示例
2018/08/24 jQuery
微信小程序中的canvas 文字断行和省略号显示功能的处理方法
2018/11/14 Javascript
配置eslint规范项目代码风格
2019/03/11 Javascript
Vue项目中ESlint规范示例代码
2019/07/04 Javascript
微信小程序实现原生步骤条
2019/07/25 Javascript
js实现鼠标拖拽div左右滑动
2020/01/15 Javascript
Angular+Ionic使用queryParams实现跳转页传值的方法
2020/09/05 Javascript
Python基于百度AI的文字识别的示例
2018/04/21 Python
Python Pillow Image Invert
2019/01/22 Python
Python matplotlib画图与中文设置操作实例分析
2019/04/23 Python
tensorflow实现二维平面模拟三维数据教程
2020/02/11 Python
DataFrame.groupby()所见的各种用法详解
2020/06/14 Python
财务管理专业应届毕业生求职信
2013/09/22 职场文书
中专生自我鉴定范文
2014/02/02 职场文书
婚纱店策划方案
2014/05/22 职场文书
体育活动总结
2015/02/04 职场文书
暗恋桃花源观后感
2015/06/12 职场文书
六一儿童节新闻稿
2015/07/17 职场文书
2016新年问候语大全
2015/11/11 职场文书
反四风问题学习心得体会
2016/01/22 职场文书
Redis中一个String类型引发的惨案
2021/07/25 Redis