Heim >Web-Frontend >js-Tutorial >Javascript操纵Cookie实现购物车程序_javascript技巧

Javascript操纵Cookie实现购物车程序_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOriginal
2016-05-16 19:23:551372Durchsuche
复制代码 代码如下:

/*****************************************************************************************************
Name    购物车
Version    1.1
Author    Vanni(凡林) url:www.27sea.com QQ:303590170
CreateDate  2005-05-31
Description
  此类是基于JavaScript和客户端Cookie,请保证客户端开启Cookie
  数据保持(默认24*30小时)可以通过 this.expire=? 小时来指定
  类中两自带的两个对象 typeObj 和 proObj 均有两个相同属性名: name 和 value 

类中数据存储形式如下-----------------------------------
Array(
new typeObj('汽车',array(
    new porObj('三菱',200),
    new proObj('本田',500)
)
  ),
  new typeObj('蛋',array(
    new proObj('鸡蛋',10),
    new proObj('鸭蛋',20)
  )
}

Cookie 存取形式为[使用escape()函数加密过]--------------
  购物车名 = 汽车#三菱:200|本田:500,蛋#鸡蛋:10|鸭蛋:20

注意:客户端存Cookie时,不会出现问题。如果要循环存储的话,可能会出现有些存入,而有些未存入
   解决方法:见下例(获得URL里的sales的数量,并存入Cookie)

文件:/depot/compareproduct.php 中的JS代码片段
<script> <BR>var car=new Car('compare'); <BR>var typeName='list'; <BR>car.delType(typeName);    //将先前对比的产品清除 <br><br>//得到URL里的参数,并分隔成数组 <BR>var url=location.href; <BR>var start=url.lastIndexOf('?sales='); <BR>var end=url.indexOf('&'); <BR>if(end==-1)end=url.length; <BR>var urlparam=url.substring(url.lastIndexOf('?sales=')+7, end ).split(','); <br><br>function setPageVal(){ <BR>  if(car.getPro(typeName).length==urlparam.length)return;    //关键部分,如果数组长度不相等说明,有些Cookie没有存入 <BR>  else{ <BR>    car.addType(typeName);            //增一个类别 <BR>    for(i=0;i<urlparam.length;i++){ <BR>      car.addPro(typeName,urlparam[i],'');  //增加对比产品,如果存在,返回假 <BR>    } <BR>    setTimeout('setPageVal();',100);      //再次调用自身,没有用递归,是因为递归速度太快,仍会有存不进的问题 <BR>  } <BR>} <br><br>setPageVal();                    //初始化数据 <br><br>function delItem(itemname){ <BR>  car.delPro(typeName,itemname); <BR>  var carData=car.getPro(typeName); <BR>  var url=''; <BR>  var carlen=carData.length; <BR>  if(carlen>1){ <BR>    for(i=0;i<carData.length;i++){ <BR>      if(i==0)  url =carData[i].name; <BR>      else    url+=','+carData[i].name; <BR>    } <BR>    document.write("waiting...."); <BR>    location.href='../depot/compareproduct.php?sales='+url; <BR>  }else{ <BR>    if(confirm('如果删除它,那么只剩一个对比项了,是否关闭此窗口?')){ <BR>      car.delCar(); <BR>      window.close(); <BR>    } <BR>  } <BR>} <BR></script>

*****************************************************************************************************/
/**
Cookie类
*/
function Cookie(){
  /**
  @desc 设置Cookie
  @return void
  */
  this.setCookie=function(name, value, hours){
    var expire = "";
    if(hours != null){
      expire = new Date((new Date()).getTime() + hours * 3600000);
      expire = "; expires=" + expire.toGMTString();
    }
    document.cookie = escape(name) + "=" + escape(value) + expire;
  }
  
  /**
  @desc 读取Cookie
  @return String
  */
  this.getCookie=function(name){
    var cookieValue = "";
    var search = escape(name) + "=";
    if(document.cookie.length > 0){ 
      offset = document.cookie.indexOf(search);
      if (offset != -1){ 
        offset += search.length;
        end = document.cookie.indexOf(";", offset);
        if (end == -1) end = document.cookie.length;
        cookieValue = unescape(document.cookie.substring(offset, end))
      }
    }
    return cookieValue;    
  }  
}

function Car(name){
  
  if( !window.clientInformation.cookieEnabled ) {
    alert('你的浏览器不支持Cookie无法使用此 购物车 系统');
    return false;
  }
  
  //##内部变量#############################################################
  
  this.carName = name;
  this.expire   = 24*30;    //购物车的有效时间(30天)
  this.carDatas = new Array();
  this.cookie   = new Cookie();
  
  //##内部对象#############################################################
  
  this.typeObj=function(name,value){  //自带的 类别 对象
    this.name =name;
    this.value="/value;
  }
  this.proObj=function(name,value){  //自带的" 商品 对象
    this.name =name;
    this.value=value;
  }
  
  //##私有方法列表##########################################################
  //
  //  getTypePoint(typeName);        //得到购物车里类别数组里的下标
  //  getProPoint(typeName,proName);    //得到购物车里类别下的产品下标
  //  saveCookie()            //以特定的形式存储此购物车的Cookie
  //
  //########################################################################
  
  /**
  @desc 得到购物车里类别数组里的下标,找到的话返回下标,否则返回 -1
  @return int
  */
  this.getTypePoint=function(typeName){
    var isok=false;
    var i=0;
    for(;i      if(this.carDatas[i].name==typeName){
        isok=true;      //找到位置
        break;
      }
    }
    if(isok)  return i;
    else    return -1;
  }
  
  /**
  @desc 得到购物车里类别下的产品下标,找到返回下标,否则返回 -1
  @return int
  */
  this.getProPoint=function(typeId,proName){
    var isok=false;
    var j = 0;
    var tempProObj=this.carDatas[typeId].value;
    for(;j      if(tempProObj[j].name==proName){
        isok=true;
        break;  
      }
    }
    if(isok)  return j;
    else    return -1;
  }
  
  /**
  @desc 存储生成的Cookie字符串
  @return void
  */
  this.saveCookie=function(){
    var outStr='';
    for( i=0; i      var typeName =this.carDatas[i].name;
      var typeValue=this.carDatas[i].value;
      var proOutStr='';
      for( j=0; j        if ( j==0 )  proOutStr = typeValue[j].name + ':' + typeValue[j].value;
        else    proOutStr += '|' + typeValue[j].name + ':' + typeValue[j].value;
      }
      if ( i==0 )  outStr = typeName + '#' + proOutStr;
      else    outStr += ',' + typeName + '#' + proOutStr;
    }
    this.cookie.setCookie(this.carName,outStr,this.expire);  //存入 Cookie  
  }
    
  //##构造语句############################################################
  
  if(this.cookie.getCookie(name)==''){
    this.cookie.setCookie(name,'',this.expire);
  }else{
    var tempTypes=this.cookie.getCookie(name).split(',');
    for(i=0;i      var tempTypeObj=tempTypes[i].split('#');
      var type_pro=new Array();
      if(tempTypeObj[1]){
        var tempProObj=tempTypeObj[1].split('|');
        for(j=0;j          var proDesc=tempProObj[j].split(':');
          type_pro.push(new this.proObj(proDesc[0],proDesc[1]));
        }
      }
      this.carDatas.push(new this.typeObj(tempTypeObj[0],type_pro));
    }
  }

  //##公共方法列表#########################################################
  //
  //  addType(typeName);          //增加一个类别
  //  addPro(typeName,proName,value);    //增加一个产品
  //  editPro(typeName,proName,value);  //修改产品的值
  //  delPro(typeName,proName);      //删除购物车内的一个类别下的产品
  //  delType(typeName);          //删除购物车内的一个类别,包括类别下的产品
  //  delCar();              //删除购物车
  //  
  //  getCar();              //得到整个购物车的数据
  //  getType();              //得到购物车内的所有类别列表
  //  getPro(typeName);          //得到购物车内指定类别下的产品列表
  //  getProVal(typeName,proName);    //得到购物车内指定类别下的产品属性
  //
  //########################################################################
  
  /**
  @desc 在购物车里增加一个类别,增加成功返回真,否则返回假
  @return bool
  */
  this.addType=function(typeName){
    if(this.getTypePoint(typeName)!=-1)    return false;        //如果已经有此类别了,返回假
    this.carDatas.push(new this.typeObj(typeName,new Array()));      //push进 自身数组
    this.saveCookie();  //存入 Cookie
    return true;
  }
  
  /**
  @desc 在购物车里增加一个产品,增加成功返回真,否则返回假
  @return bool
  */
  this.addPro=function(typeName,proName,value){
    var typePoint=this.getTypePoint(typeName);      if ( typePoint ==-1 ) return false;    //没有此类别,无法增加,返回假
    var proPoint =this.getProPoint(typePoint,proName);  if ( proPoint != -1 ) return false;    //有此产品了,无法增加重复,返回假
    this.carDatas[typePoint].value.push(new this.proObj(proName,value));  //push到自身数组
    this.saveCookie();  //存入 Cookie
    return true;
  }
  
  /**
  @desc 修改购物车里的产品属性
  @return bool
  */
  this.editPro=function(typeName,proName,value){
    var typePoint=this.getTypePoint(typeName);      if ( typePoint == -1 ) return false;  //没有此类别,无法修改,返回假
    var proPoint =this.getProPoint(typePoint,proName);  if ( proPoint == -1 ) return false;  //没有此产品,无法修改,返回假
    this.carDatas[typePoint].value[proPoint].value=value;              //更新自身 
    this.saveCookie();  //存入 Cookie
    return true;
  }
  
  /**
  @desc 删除一个产品
  @return bool
  */
  this.delPro=function(typeName,proName){
    var typePoint=this.getTypePoint(typeName);      if ( typePoint == -1 ) return false;  //没有此类别,无法删除,返回假
    var proPoint =this.getProPoint(typePoint,proName);  if ( proPoint == -1 ) return false;  //没有此产品,无法删除,返回假
    var pros=this.carDatas[typePoint].value.length;
    this.carDatas[typePoint].value[proPoint] = this.carDatas[typePoint].value[pros-1];  //最后一个产品放置要删除的产品上
    this.carDatas[typePoint].value.pop();
    this.saveCookie();  //存入 Cookie
    return true;
  }
  
  /**
  @desc 删除一个类别
  @return bool
  */
  this.delType=function(typeName){
    var typePoint=this.getTypePoint(typeName);  if ( typePoint == -1 ) return false;  //没有此类别,无法删除,返回假
    var types=this.carDatas.length;
    this.carDatas[typePoint] = this.carDatas[types-1];            //删除类别
    this.carDatas.pop();
    this.saveCookie();  //存入 Cookie
    return true;
  }
  
  /**
  @desc 删除此购物车
  @return void
  */
  this.delCar=function(){
    this.cookie.setCookie(this.carName,'',0);
    this.carDatas=new Array();
    this.saveCookie();  //存入 Cookie
  }
  
  /**
  @desc 获得购物车数据
  @return Array
  */
  this.getCar=function(){
    return this.carDatas;
  }
  
  /**
  @desc 获得类别列表
  @return Array
  */
  this.getType=function(){
    var returnarr=new Array();
    for ( i=0; i    return returnarr;
  }
  
  /**
  @desc 获得类别下的产品列表
  @return Array
  */
  this.getPro=function(typeName){
    var typePoint=this.getTypePoint(typeName);  if ( typePoint == -1 ) return false;  //没有此类别,返回假
    return this.carDatas[typePoint].value;
  }
  
  /**
  @desc 获得商品属性
  @return String
  */
  this.getProVal=function(typeName,proName){
    var typePoint=this.getTypePoint(typeName);      if ( typePoint == -1 ) return false;  //没有此类别,返回假
    var proPoint =this.getProPoint(typePoint,proName);  if ( proPoint == -1 ) return false;  //没有此产品,返回假
    return this.carDatas[typePoint].value[proPoint].value;
  }
}

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn