300字范文,内容丰富有趣,生活中的好帮手!
300字范文 > 微信小程序商城开发之实现商品加入购物车的功能(code)

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

时间:2021-10-07 10:06:01

相关推荐

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

微信小程序|小程序开发

微信小程序,小程序电商

微信小程序-小程序开发

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

asp手机站源码sp源代码,ubuntu如何安装cx,爬虫框架scrapy功能,php坏处,brian seo歌手lzw

看效果

红色物流企业源码,vscode npm运行,飞书ubuntu,tomcat 托盘程序,sqlite查询成绩表,织梦网站tag自定义插件,前端页面搞好了怎么用框架,爬虫的工作能长久吗,并且 php,广州知名seo厂家,phpmysql网站模板,html5炫酷网页代码,帝国更换模板lzw

匿名留言网页源码,vscode字符乱码修改,ubuntu gcc安装,tomcat 部署 配置,sqlite实时备份,什么是网页设计模版,pdo 选择数据库,阿里企业邮箱服务器地址,jquery 上传图片插件,前端常用样式框架有哪些,爬虫异族,php 数组转字符串,seo检查,springboot拍卖,a标签 inline-block,文学网站cms,js读取网页源码,shopex 手机模板,织梦留言板后台管理,wordpress 插入页面,jqueryeasyui后台管理系统源码,俄罗斯方块c 程序lzw

购物车.jpg

开发计划

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

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

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

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

detail.wxml

绑定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) } }

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

cart.wxml

购物车空空如也 去抢购{{item.title}} ¥{{item.price * item.count}} 全选 合计:¥{{totalMoney}}

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,}); } },

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

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 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; // 商品总数量+1if (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 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实现特卖商品的流式布局代码

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。