黔优媒体网-软文媒体自助发稿平台!
  1. 行业资讯
  2. 正文

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

来源:黔优媒体网   时间:2024-09-19

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

看效果

购物车.gif

开发计划

1、商品详情页将商品信息放入缓存
2、购物车页面读取缓存获取商品信息
3、购物车商品计算和删除缓存商品

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

detail.wxml

 button data-goodid= {{goods.goodsId}} >

绑定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) + #39;... #39;;
 // 获取购物车的缓存数组(没有数据,则赋予一个空数组) 
 var arr = wx.getStorageSync( #39;cart #39;) || []; 
 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( #39;cart #39;, arr)
 } catch (e) { 
 console.log(e)
 //关闭窗口
 wx.showToast({ 
 title: #39;加入购物车成功! #39;, 
 icon: #39;success #39;, 
 duration: 2000
 }); 
 this.closeDialog(); 
 // 返回(在if内使用return,跳出循环节约运算,节约性能) 
 return;
 // 遍历完购物车后,没有对应的item项,把goodslist的当前项放入购物车数组 
 arr.push(goods);
 } else {
 arr.push(goods);
 // 最后,把购物车数据,存放入缓存 
 try {
 wx.setStorageSync( #39;cart #39;, arr) 
 // 返回(在if内使用return,跳出循环节约运算,节约性能) 
 //关闭窗口
 wx.showToast({ 
 title: #39;加入购物车成功! #39;, 
 icon: #39;success #39;, 
 duration: 2000
 }); 
 this.closeDialog(); 
 return;
 } catch (e) { 
 console.log(e)
 }

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

cart.wxml

 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;

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( #39;cart #39;) || []; 
 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: #39;去结算 #39;, 
 icon: #39;success #39;, 
 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( #39;cart #39;, this.data.carts); 
 this.priceCount();
 } else { 
 this.setData({ 
 cart: this.data.carts, 
 iscart: false, 
 hidden: true,
 wx.setStorageSync( #39;cart #39;, []);
 }

相关推荐:

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

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


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

微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!


【免责申明】黔优媒体网以上展示内容来源于用户自主上传、合作媒体、企业机构或网络收集整理,版权争议与本站无关,文章涉及见解与观点不代表黔优媒体网官方立场,请读者仅做参考,本文标题:微信小程序商城开发之实现商品加入购物车的功能(代码);欢迎转载,转载时请说明出处。若您认为本文侵犯了您的版权信息,或您发现该内容有任何违法/违规的内容,请您立即联系我们及时修正或删除。(邮箱号: kefu@qianu.com)