答案:复制代码 代码如下:
/*****************************************************************************************************
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 language="javascript">
var car=new Car('compare');
var typeName='list';
car.delType(typeName); //将先前对比的产品清除
//得到URL里的参数,并分隔成数组
var url=location.href;
var start=url.lastIndexOf('?sales=');
var end=url.indexOf('&');
if(end==-1)end=url.length;
var urlparam=url.substring(url.lastIndexOf('?sales=')+7, end ).split(',');
function setPageVal(){
if(car.getPro(typeName).length==urlparam.length)return; //关键部分,如果数组长度不相等说明,有些Cookie没有存入
else{
car.addType(typeName); //增一个类别
for(i=0;i<urlparam.length;i++){
car.addPro(typeName,urlparam[i],''); //增加对比产品,如果存在,返回假
}
setTimeout('setPageVal();',100); //再次调用自身,没有用递归,是因为递归速度太快,仍会有存不进的问题
}
}
setPageVal(); //初始化数据
function delItem(itemname){
car.delPro(typeName,itemname);
var carData=car.getPro(typeName);
var url='';
var carlen=carData.length;
if(carlen>1){
for(i=0;i<carData.length;i++){
if(i==0) url =carData[i].name;
else url+=','+carData[i].name;
}
document.write("waiting....");
location.href=> }else{
if(confirm('如果删除它,那么只剩一个对比项了,是否关闭此窗口?')){
car.delCar();
window.close();
}
}
}
</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<this.carDatas.length;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<tempProObj.length;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<this.carDatas.length; i++ ){
var typeName =this.carDatas[i].name;
var typeValue=this.carDatas[i].value;
var proOutStr='';
for( j=0; j<typeValue.length; 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<tempTypes.length;i++){
var tempTypeObj=tempTypes[i].split('#');
var type_pro=new Array();
if(tempTypeObj[1]){
var tempProObj=tempTypeObj[1].split('|');
上一个:重定向实现代码
下一个:表单内同名元素的控制
- 更多JS疑问解答:
- 几个验证11位手机号码格式的js代码
- js把图片转换成 base64代码
- js把base代码转换成图片
- JS 将 base64编码的图片转化为图片文件
- js中的定时器
- js如何获得FCKeditor控件的值
- 用js限制投票的cookie .目前设置的为:<input type="" class="" onclick="'window.location...
- JS验证,这块“牛皮”反复修改都不能实现
- 在JS中使用DOM模型
- 如何用JS 获取本地文件夹的文件列表
- js中new 了两个Object数组。怎么样将数组内容合并,重复的内容?
- 求实现自动生成图片缩略图的JS代码
- JS脚本网页问题
- js,代码中"object"和"Object"区别?
- js+flash实现网页图片切换效果,出现边框,单击激活此控件。