百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

微信小程序商城开发之实现商品加入购物车的功能(代码)

yuyutoo 2024-10-13 09:13 17 浏览 0 评论

本篇文章给大家带来的内容是关于微信小程序商城开发之实现商品加入购物车的功能(代码) ,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

看效果

购物车.gif

开发计划

1、商品详情页将商品信息放入缓存

2、购物车页面读取缓存获取商品信息

3、购物车商品计算和删除缓存商品

一、商品详情页将商品信息放入缓存

detail.wxml

<button data-goodid="{{goods.goodsId}}" class="button-addCar" bindtap="addCar" formType="submit">确定</button>

绑定bindtap事件将商品加入购物车。

detail.js

/**
 * 加入购物车
 */
 addCar: function (e) { 
 var goods = this.data.goods;
 goods.isSelect=false; 
 var count = this.data.goods.count; 
 var title = this.data.goods.title; 
 if (title.length > 13) {
 goods.title = title.substring(0, 13) + '...';
 } 
 // 获取购物车的缓存数组(没有数据,则赋予一个空数组) 
 var arr = wx.getStorageSync('cart') || []; 
 console.log("arr,{}", arr); 
 if (arr.length > 0) { 
 // 遍历购物车数组 
 for (var j in arr) { 
 // 判断购物车内的item的id,和事件传递过来的id,是否相等 
 if (arr[j].goodsId == goodsId) { 
 // 相等的话,给count+1(即再次添加入购物车,数量+1) 
 arr[j].count = arr[j].count + 1; 
 // 最后,把购物车数据,存放入缓存(此处不用再给购物车数组push元素进去,因为这个是购物车有的,直接更新当前数组即可) 
 try {
 wx.setStorageSync('cart', arr)
 } catch (e) { 
 console.log(e)
 } 
 //关闭窗口
 wx.showToast({ 
 title: '加入购物车成功!', 
 icon: 'success', 
 duration: 2000
 }); 
 this.closeDialog(); 
 // 返回(在if内使用return,跳出循环节约运算,节约性能) 
 return;
 }
 } 
 // 遍历完购物车后,没有对应的item项,把goodslist的当前项放入购物车数组 
 arr.push(goods);
 } else {
 arr.push(goods);
 } 
 // 最后,把购物车数据,存放入缓存 
 try {
 wx.setStorageSync('cart', arr) 
 // 返回(在if内使用return,跳出循环节约运算,节约性能) 
 //关闭窗口
 wx.showToast({ 
 title: '加入购物车成功!', 
 icon: 'success', 
 duration: 2000
 }); 
 this.closeDialog(); 
 return;
 } catch (e) { 
 console.log(e)
 }
 }

二、购物车页面读取缓存获取商品信息

cart.wxml

<view class="J-shopping-cart-empty" hidden="{{iscart}}"><view class="shopping-cart-empty">
 <view class="bg"></view> 
 <view class="cart"></view>
 <text class='empty-text'>购物车空空如也</text> 
 <p></p>
 <navigator url="/pages/goods/goods">
 <a href="//m.vip.com" class="button button-primary" >
 去抢购 </a>
 </navigator>
 </view></view> <view class="scroll" hidden="{{hidden}}"><scroll-view class="scroll" scroll-y="true">
 <view class="separate"></view>
 <view wx:for="{{carts}}">
 <view class="cart_container"> 
 <view wx:if="{{!item.isSelect}}">
 <icon class="item-select" bindtap="switchSelect" data-index="{{index}}" data-id="{{index}}" type="circle" size="20"></icon>
 </view>
 <view wx:elif="{{item.isSelect}}">
 <icon class="item-select" bindtap="switchSelect" data-index="{{index}}" data-id="{{index}}" type="success" color="#f0145a" size="20"></icon>
 </view>
 <image class="item-image" src="{{item.imgUrl}}"></image>
 <import src="../template/template.wxml" />
 <view class="column">
 <text class="title">{{item.title}}</text>
 <image bindtap="delGoods" id="img{{index}}" data-index="{{index}}" src="../../images/del.png"></image> 
 <view class="row">
 <text class="sku-price">¥{{item.price * item.count}}</text>
 <view class="sku">
 <template is="quantity" data="{{ ...item,index:index}}" /> 
 </view>
 </view>
 </view>
 </view>
 <view class="separate"></view>
 </view></scroll-view></view>
 <view class="bottom_total" hidden="{{hidden}}">
 <view class="bottom_line"></view>
 <view class="row">
 <view wx:if="{{!isAllSelect}}">
 <icon class="item-allselect" bindtap="allSelect" type="circle" size="20"></icon>
 </view>
 <view wx:elif="{{isAllSelect}}">
 <icon class="item-allselect" bindtap="allSelect" type="success" color="#f0145a" size="20"></icon>
 </view>
 <text class="small_text">全选</text>
 <text>合计:¥ </text>
 <text class="price">{{totalMoney}}</text>
 <button class="button-red" bindtap="toBuy" formType="submit">去结算 </button>
 </view></view>

cart.wxss

 @import "../template/template.wxss"; 
page{ 
 background: #f3f4f5; 
 /* font-size: 37.5px; */
} 
 .column image { 
 width:33rpx; 
 height:35rpx; 
 display:inline-block; 
 overflow:hidden; 
 float:right; 
 margin-top: -40rpx; 
 margin-left:400rpx;
} 
 .J-shopping-cart-empty{ 
 margin: 0; 
 padding: 0; 
 border: 0; 
 font: inherit; 
 font-size: 100%; 
 vertical-align: baseline;
}
.shopping-cart-empty { 
 height: 250px; 
 padding-top: 3.2rem; 
 padding-bottom: 1.6rem; 
 background-color: #fff; 
 text-align: center; 
 position: relative;
} 
.shopping-cart-empty .bg{ 
 position: absolute; 
 width: 16.29333rem; 
 height: 6.73333rem; 
 
 background: transparent url(); 
 left: 50%; 
 -webkit-transform: translateX(-50%); 
 transform: translateX(-50%); 
 background-size: 100%; 
 top: 0;
} 
.shopping-cart-empty .cart{ 
 width: 5.83333rem; 
 height: 7.46rem; 
 background: transparent url() no-repeat; 
 background-size: 100%; 
 margin: 0 auto;
} 
.shopping-cart-empty .button { 
 width: 8.46667rem; 
 height: 1.5rem; 
 display: block; 
 margin: 20rpx auto;
}
.empty-text { 
 font-size: .64667rem; 
 color: #222; 
 margin-top: .53333rem; 
 line-height: .74667rem; 
 font-weight: 400;
}
.button-primary { 
 border: 1px solid #de3c96; 
 color: #de3c96; 
 text-decoration: none; 
 text-align: center; 
 display: block; 
 border-radius: .21267rem; 
 line-height: 1.5rem; 
 -webkit-appearance: none; 
 background: none; 
 padding: 0 .26667rem; 
 margin: 0; 
 white-space: nowrap; 
 position: relative; 
 text-overflow: ellipsis; 
 font-size: .74333rem; 
 font-family: inherit; 
 cursor: pointer; 
 user-select: none;
} 
.cart_container { 
 display: flex; 
 flex-direction: row; 
 background-color: #FFFFFF; 
 margin-bottom: 10rpx;
}
.scroll { 
 margin-bottom: 120rpx; 
}
.column { 
 display: flex; 
 flex-direction: column;
}
.row { 
 display: flex; 
 flex-direction: row; 
 align-items: center;
}
.sku { 
 margin-left: 100rpx; 
 position: absolute; 
 right: 30rpx; 
 margin-top: 30rpx; 
}
.sku-price { 
 color: red; 
 position: relative; 
 margin-top: 30rpx; 
}
.price { 
 color: red; 
 position: relative;
}
.title { 
 font-size: 32rpx; 
 margin-top: 40rpx;
}
.small_text { 
 font-size: 28rpx; 
 margin-right: 40rpx; 
 margin-left: 25rpx;
}
.item-select { 
 width: 40rpx; 
 height: 40rpx; 
 margin-top: 90rpx; 
 margin-left: 20rpx;
}
.item-allselect { 
 width: 40rpx; 
 height: 40rpx; 
 margin-left: 20rpx; 
 margin-top:25rpx; 
}
.item-image { 
 width: 180rpx; 
 height: 180rpx; 
 margin: 20rpx;
} 
.bottom_line { 
 width: 100%; 
 height: 2rpx; 
 background: lightgray;
} 
.bottom_total { 
 position: fixed; 
 display: flex; 
 flex-direction: column; 
 bottom: 0; 
 width: 100%; 
 height: 120rpx; 
 line-height: 120rpx; 
 background: white; /* margin-top: 300rpx; */
 border-top: 1rpx solid #ccc; z-index: 99;
}
.button-red { 
 background-color: #f0145a; 
 position: fixed; 
 right: 0; 
 color: white; 
 text-align: center; 
 display: inline-block; 
 font-size: 30rpx; 
 border-radius: 0rpx; 
 width: 30%; 
 height: 120rpx; 
 line-height: 120rpx; /* border: 1rpx solid #ccc; */
}

cart.js

/**
 * 页面的初始数据
 */
 data: { 
 carts: [], //数据 
 iscart: false, 
 hidden: null, 
 isAllSelect: false, 
 totalMoney: 0,
 },
onShow: function () { 
 // 获取产品展示页保存的缓存数据(购物车的缓存数组,没有数据,则赋予一个空数组) 
 var arr = wx.getStorageSync('cart') || []; 
 console.info("缓存数据:"+arr); // 有数据的话,就遍历数据,计算总金额 和 总数量 
 if (arr.length > 0) { 
 // 更新数据 
 this.setData({ 
 carts: arr, 
 iscart: true, 
 hidden: false
 }); 
 console.info("缓存数据:" + this.data.carts);
 }else{ 
 this.setData({ 
 iscart: false, 
 hidden: true,
 });
 }
 },

三、购物车商品计算和删除缓存商品

cart.js

//勾选事件处理函数 
 switchSelect: function (e) { 
 // 获取item项的id,和数组的下标值 
 var Allprice = 0, i = 0; 
 let id = e.target.dataset.id,
 index = parseInt(e.target.dataset.index); 
 this.data.carts[index].isSelect = !this.data.carts[index].isSelect; //价钱统计
 if (this.data.carts[index].isSelect) { 
 this.data.totalMoney = this.data.totalMoney + (this.data.carts[index].price * this.data.carts[index].count);
 } else { 
 this.data.totalMoney = this.data.totalMoney - (this.data.carts[index].price * this.data.carts[index].count);
 } 
 //是否全选判断
 for (i = 0; i < this.data.carts.length; i++) {
 Allprice = Allprice + (this.data.carts[index].price * this.data.carts[index].count);
 } 
 if (Allprice == this.data.totalMoney) { 
 this.data.isAllSelect = true;
 } else { 
 this.data.isAllSelect = false;
 } 
 this.setData({ 
 carts: this.data.carts, 
 totalMoney: this.data.totalMoney, 
 isAllSelect: this.data.isAllSelect,
 })
 }, 
 //全选
 allSelect: function (e) { 
 //处理全选逻辑
 let i = 0; 
 if (!this.data.isAllSelect) { 
 this.data.totalMoney = 0; 
 for (i = 0; i < this.data.carts.length; i++) { 
 this.data.carts[i].isSelect = true; 
 this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count);
 }
 } else { 
 for (i = 0; i < this.data.carts.length; i++) { 
 this.data.carts[i].isSelect = false;
 } 
 this.data.totalMoney = 0;
 } 
 this.setData({ 
 carts: this.data.carts, 
 isAllSelect: !this.data.isAllSelect, 
 totalMoney: this.data.totalMoney,
 })
 }, // 去结算
 toBuy() {
 wx.showToast({ 
 title: '去结算', 
 icon: 'success', 
 duration: 3000
 }); 
 this.setData({ 
 showDialog: !this.data.showDialog
 });
 }, //数量变化处理
 handleQuantityChange(e) { 
 var componentId = e.componentId; 
 var quantity = e.quantity; 
 this.data.carts[componentId].count.quantity = quantity; 
 this.setData({ 
 carts: this.data.carts,
 });
 }, 
 /* 减数 */
 delCount: function (e) { 
 var index = e.target.dataset.index; 
 console.log("刚刚您点击了加一"); 
 var count = this.data.carts[index].count; // 商品总数量-1
 if (count > 1) { 
 this.data.carts[index].count--;
 } 
 // 将数值与状态写回 
 this.setData({ 
 carts: this.data.carts
 }); 
 console.log("carts:" + this.data.carts); 
 this.priceCount();
 }, 
 /* 加数 */
 addCount: function (e) { 
 var index = e.target.dataset.index; 
 console.log("刚刚您点击了加+"); 
 var count = this.data.carts[index].count; // 商品总数量+1 
 if (count < 10) { 
 this.data.carts[index].count++;
 } 
 // 将数值与状态写回 
 this.setData({ 
 carts: this.data.carts
 }); 
 console.log("carts:" + this.data.carts); 
 this.priceCount();
 }, 
 priceCount: function (e) { 
 this.data.totalMoney = 0; 
 for (var i = 0; i < this.data.carts.length; i++) { 
 if (this.data.carts[i].isSelect == true) { 
 this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count);
 }
 } 
 this.setData({ 
 totalMoney: this.data.totalMoney,
 })
 }, 
 /* 删除item */
 delGoods: function (e) { 
 this.data.carts.splice(e.target.id.substring(3),1); // 更新data数据对象 
 if (this.data.carts.length > 0) { 
 this.setData({ 
 carts: this.data.carts
 })
 wx.setStorageSync('cart', this.data.carts); 
 this.priceCount();
 } else { 
 this.setData({ 
 cart: this.data.carts, 
 iscart: false, 
 hidden: true,
 })
 wx.setStorageSync('cart', []);
 }
 }

相关推荐:

微信小程序商城开发之动态API把商品进行分类(代码)

微信小程序商城开发之动态API实现特卖商品的流式布局代码

以上就是微信小程序商城开发之实现商品加入购物车的功能(代码)的详细内容,更多请关注其它相关文章!

更多技巧请《转发 + 关注》哦!

相关推荐

Python操作Word文档神器:python-docx库从入门到精通

Python操作Word文档神器:python-docx库从入门到精通动动小手,点击关注...

Python 函数调用从入门到精通:超详细定义解析与实战指南 附案例

一、函数基础:定义与调用的核心逻辑定义:函数是将重复或相关的代码块封装成可复用的单元,通过函数名和参数实现特定功能。它是Python模块化编程的基础,能提高代码复用性和可读性。定义语法:...

等这么长时间Python背记手册终于来了,入门到精通(视频400集)

本文毫无套路!真诚分享!前言:无论是学习任何一门语言,基础知识一定要扎实,基础功非常的重要,找一个有丰富编程经验的老师或者师兄带着你会少走很多弯路,你的进步速度也会快很多,无论我们学习的目的是什么,...

图解Python编程:从入门到精通系列教程(附全套速查表)

引言本系列教程展开讲解Python编程语言,Python是一门开源免费、通用型的脚本编程语言,它上手简单,功能强大,它也是互联网最热门的编程语言之一。Python生态丰富,库(模块)极其丰富,这使...

Python入门教程(非常详细)从零基础入门到精通,看完这一篇就够

本书是Python经典实例解析,采用基于实例的方法编写,每个实例都会解决具体的问题和难题。主要内容有:数字、字符串和元组,语句与语法,函数定义,列表、集、字典,用户输入和输出等内置数据结构,类和对象,...

Python函数全解析:从入门到精通,一文搞定!

1.为什么要用函数?函数的作用:封装代码,提高复用性,减少重复,提高可读性。...

Python中的单例模式:从入门到精通

Python中的单例模式:从入门到精通引言单例模式是一种常用的软件设计模式,它保证了一个类只有一个实例,并提供一个全局访问点。这种模式通常用于那些需要频繁创建和销毁的对象,比如日志对象、线程池、缓存等...

【Python王者归来】手把手教你,Python从入门到精通!

用800个程序实例、5万行代码手把手教你,Python从入门到精通!...

Python从零基础入门到精通:一个月就够了

如果想从零基础到入门,能够全职学习(自学),那么一个月足够了。...

Python 从入门到精通:一个月就够了

要知道,一个月是一段很长的时间。如果每天坚持用6-7小时来做一件事,你会有意想不到的收获。作为初学者,第一个月的月目标应该是这样的:熟悉基本概念(变量,条件,列表,循环,函数)练习超过30个编...

Python零基础到精通,这8个入门技巧让你少走弯路,7天速通编程!

Python学习就像玩积木,从最基础的块开始,一步步搭建出复杂的作品。我记得刚开始学Python时也是一头雾水,走了不少弯路。现在回头看,其实掌握几个核心概念,就能快速入门这门编程语言。来聊聊怎么用最...

神仙级python入门教程(非常详细),从0到精通,从看这篇开始!

python入门虽然简单,很多新手依然卡在基础安装阶段,大部分教程对一些基础内容都是一带而过,好多新手朋友,对一些基础知识常常一知半解,需要在网上查询很久。...

Python类从入门到精通,一篇就够!

一、Python类是什么?大家在生活中应该都见过汽车吧,每一辆真实存在、能在路上跑的汽车,都可以看作是一个“对象”。那这些汽车是怎么生产出来的呢?其实,在生产之前,汽车公司都会先设计一个详细的蓝图...

学习Python从入门到精通:30天足够了,这才是python基础的天花板

当年2w买的全套python教程用不着了,现在送给有缘人,不要钱,一个月教你从入门到精通1、本套视频共487集,本套视频共分4季...

30天Python 入门到精通(3天学会python)

以下是一个为期30天的Python入门到精通学习课程,专为零基础新手设计。课程从基础语法开始,逐步深入到面向对象编程、数据处理,最后实现运行简单的大语言模型(如基于HuggingFace...

取消回复欢迎 发表评论: