看效果web

购物车.gif小程序

开发计划微信小程序

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

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

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

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

detail.wxml缓存

肯定

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

detail.jsapp

/**

* 加入购物车

*/

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)

}

}

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

cart.wxmlxss

购物车空空如也

去抢购

{{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,

});

}

},

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

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', []);

}

}

备注

微信小程序微商城系列 都是经过https 动态获取数据并展现的,建议从第一篇开始阅读。你们多多支持本系列文章会继续更新下去,谢谢各位!你们在使用过程当中有哪些建议能够提出来,咱们一块儿学习哈~~~

微信小程序微商城系列

关注咱们

若是须要源码能够关注“IT实战联盟”公*众*号并留言(微商城源码,5个字会收到源码下载地址,必定要看源码里面的操做手册会少走不少弯路),也能够加入交流群和做者互撩哦~~~

微信小程序srt_微信小程序微商城(八):缓存实现商品购物车功能相关推荐

  1. 微信小程序微商城(八):缓存实现商品购物车功能

    IT实战联盟博客:http://blog.100boot.cn 上一篇:微信小程序微商城(七):动态API实现商品分类 看效果 购物车.gif 开发计划 1.商品详情页将商品信息放入缓存 2.购物车页 ...

  2. 【愚公系列】2022年10月 微信小程序-电商项目-商品购物车功能实现

    文章目录 前言 一.商品购物车功能实现 二.效果 前言 在电商的核心交易流程中,购物车是其中非常重要的一环,它承担商品加购.价格计算.促销活动展示等功能,与会员系统.商品系统.库存系统.订单系统等紧密 ...

  3. 微信小程序,分销系统,微商城 (广州企客猫微信小程序开发定制公司)

    有什么好处 商家为什么要做微信小程序. 其实小程序的火爆其根本在于旺盛的市场需求.小程序的诞生解决了两个方 小程是什么???      小程序是一种无需下载安装,即可使用的手机应用.只需要扫描二维码, ...

  4. 微信小程序微商城(九):微信授权并实现个人中心页面页面

    IT实战联盟博客:http://blog.100boot.cn 上一篇:微信小程序微商城(八):缓存实现商品购物车功能 看效果 开发计划 1.实现微信授权并获取用户信息 2.个人中心页面布局 一.实现 ...

  5. 基于go语言结合微信小程序开发的微商城系统

    最近我录制的一门<Golang微信小程序微商城系统原型>,这门免费课程特别适合在校大学生或者刚毕业的大学生,go语言初学者以及想要从事微商城开发项目入门的小伙伴们来学习.在课程当中我不仅仅 ...

  6. 如何开通微信商城?微商城的开通方法?

    开通微信商城很简单,步骤如下: 第一步:在微信公众平台注册微信服务号,并且开通微信支付. 第二步:找第三方微商城平台购买微商城系统,将购买的微商城系统和申请的微信服务号绑定. 第三步:在微商城系统内装 ...

  7. 微信小程序微商城(五):动态API实现商品详情页(下)

    IT实战联盟博客:http://blog.100boot.cn 上一篇:微信小程序微商城(四):动态API实现商品详情页(上) 看效果 加入购物车.gif 开发计划 1.加入购物车悬浮框.商品数量.价 ...

  8. (开源)基于vue, react, node.js, go开发的微商城(含微信小程序)

    微商城 地址: https://github.com/shen100/wemall 求star,求关注 项目截图 微信小程序 项目环境搭建 1 克隆代码 git clone https://githu ...

  9. node.js+小程序基于微信小程序的校园失物招领系统毕业设计源码072343

    微信小程序的校园失物招领系统 摘  要 随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱,微信小程序的校 ...

最新文章

  1. TACACS +和RADIUS比较
  2. [原创]django+ldap+memcache实现单点登录+统一认证
  3. ios main函数之前的操作_添加函数在ARM在进入main函数之前
  4. 格力电器:回购股份比例超3% 已耗资95.15亿元
  5. c语言仓库即存储器,计算机基础4
  6. $.ajax提交,后台接受到的值总是乱码?明天再总结
  7. 《基于多支持向量机综合的电力系统暂态稳定评估》总结
  8. 跨境电商指南:如何处理客户投诉
  9. Artistic Style Dev CPP 运算符 前后空格
  10. 信息系统项目管理师思维导图
  11. 查看变量内存的python内置函数是_这68个Python内置函数,建议你吃透
  12. 计算机中数值怎么比较大小,数值比较器,数值比较器的作用和原理是什么?
  13. 怎么给表格加一列序号_(表格的序号怎么顺下来)如何在excel表格填充一列序号列...
  14. 源码多多-Discuz x2.5 论坛防灌水机制分析和设置方法
  15. 2021_01_04
  16. R155附录5 Part A
  17. 华米手表2 是android,使用华米2手表近3个月,简单交流一下真实使用感受,侧重游泳...
  18. 《1Q84》--[日]村上春树
  19. win10+VS2017编译配置boost_1_78_0
  20. python3爬虫系列24之重庆微博地铁客运量爬取且可视化输出

热门文章

  1. tkinter 隐藏_python Tkinter()如何隐藏UI
  2. java 内存管理 知乎_[知乎]Java 语言的 GC 为什么不实时释放内存?
  3. java学到什么程度安卓_自学Android到什么程度才能找到工作?
  4. windows 传输目录文件到linux pscp: xxx: not a regular file
  5. MySQL中的事务隔离级别
  6. 【爬虫剑谱】一卷1章 软件篇-Mongodb的安装及配置
  7. 为什么建议使用count(*)来统计数据行数
  8. java when for where_JAVA_EE_MyBatis之动态SQL
  9. 下行物理信道rs_这些CH结尾的LTE物理信道傻傻分不清楚?快来看这篇文章!
  10. android开发入门与实践_我的新书《Android App开发入门与实战》已经出版