微信小程序实现购物车代码实例详解


Posted in Javascript onAugust 29, 2019

其实购物车都是类似的实现方法,只不过小程序是有他的数据层和业务层,在这里把之前的做法记录一下,分享出来也希望能给需要的小伙伴带来参考价值在最开始的时候先从本地存储中获取购物车数据,因为我们会切换页面 在页面切换的过程中需要实时重新加载购物车的数据,所以我们把获取的方法写在onShow中,而不是onLoad中:

onShow: function () {
  const cart = wx.getStorageSync("cart");
  let address = wx.getStorageSync("address") ;
  console.log(address);
  this.setData({
   address, cart
  })
  this.loadCarts();
  this.countAll();
 }

点击按钮更改购物车的数量:

handleNumEdit(e) {
  const { operator, goodsid } = e.target.dataset;
  let { cart } = this.data;
  cart[goodsid].count += (+operator);
  if (cart[goodsid].count < 1) {
   cart[goodsid].count = 1;
   wx.showModal({
    title: '提示',
    content: '您确定要删除吗',
    showCancel: true,
    cancelText: '取消',
    cancelColor: '#000000',
    confirmText: '确定',
    confirmColor: '#3CC51F',
    success: (result) => {
     if (result.confirm) {
      delete cart[goodsid];
      this.loadCarts();
      this.countAll();
     } else {
     }
    }
   });
  } else if (cart[goodsid].count > cart[goodsid].goods_number) {
   cart[goodsid].count = cart[goodsid].goods_number;
   wx.showToast({
    title: '没有库存了',
    icon: 'none',
    duration: 1500,
    mask: true
   });
  }
  this.loadCarts();
  this.countAll();
 }

加载购物车数据的方法:

data: {
  cart: {},
  address: {},
  totalPrice: 0,
  categoryLength: 0,
  isAllChecked: true
 },

单个商品被选中时触发:

loadCarts() {
  let { cart } = this.data;
  let isAllChecked = true;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    const element = cart[key];
    if (!element.isChecked) {
     isAllChecked = false;
     break;
    }
   }
  }
  this.setData({
   cart,
   isAllChecked
  });
 },

全选和反选触发的事件:

handleItemChecked(e) {
  let { goodsid } = e.target.dataset;
  let { cart } = this.data;
  let { isChecked } = cart[goodsid];
  cart[goodsid].isChecked = !isChecked;
  let checkedLength = 0;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    if (cart[key].isChecked) {
     checkedLength++;
    }
   }
  }
  const isAllChecked = checkedLength == Object.keys(cart).length;
  this.countAll();
  this.setData({
   isAllChecked
  })
 },

点击结算时触发:

handleItemAllChecked() {
  let { isAllChecked } = this.data;
  let { cart } = this.data;
  isAllChecked = !isAllChecked;
  for (const key in cart) {
   if (cart.hasOwnProperty(key)) {
    cart[key].isChecked = isAllChecked;
   }
  }
  this.setData({
   isAllChecked,
   cart
  })
  this.countAll();
 },

纯js代码,可能有一定小程序代码经验的会看得轻松一点。以上便可以实现在对购物车的商品进行加减和全选与反选,以及对商品进行数量合计并计算价格。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 页面载入进度条实现代码
Feb 08 Javascript
javascript之AJAX框架使用说明
Apr 24 Javascript
表单的焦点顺序tabindex和对应enter键提交
Jan 04 Javascript
javascript:window.open弹出窗口的位置问题
Mar 18 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
Mar 13 Javascript
js实现table添加行tr、删除行tr、清空行tr的简单实例
Oct 15 Javascript
JavaScript实现窗口抖动效果
Oct 19 Javascript
vue2.0+koa2+mongodb实现注册登录
Apr 10 Javascript
JavaScript实现的文本框placeholder提示文字功能示例
Jul 25 Javascript
Angular Material Icon使用详解
Nov 07 Javascript
zepto.js 实时监听输入框的方法
Dec 04 Javascript
JavaScript字符串处理常见操作方法小结
Nov 15 Javascript
vue图片加载失败时用默认图片替换的方法
Aug 29 #Javascript
vue 框架下自定义滚动条(easyscroll)实现方法
Aug 29 #Javascript
Angular8路由守卫原理和使用方法
Aug 29 #Javascript
Vue中的循环及修改差值表达式的方法
Aug 29 #Javascript
vue父子组件通信的高级用法示例
Aug 29 #Javascript
Elementui表格组件+sortablejs实现行拖拽排序的示例代码
Aug 28 #Javascript
JS中async/await实现异步调用的方法
Aug 28 #Javascript
You might like
php 模拟 asp.net webFrom 按钮提交事件实例
2014/10/13 PHP
Yii分页用法实例详解
2014/12/04 PHP
php实现从上传文件创建缩略图的方法
2015/04/02 PHP
php技术实现加载字体并保存成图片
2015/07/27 PHP
如何使用GDB调试PHP程序
2015/12/08 PHP
LNMP部署laravel以及xhprof安装使用教程
2017/09/14 PHP
PHP基于进程控制函数实现多线程
2020/12/09 PHP
JavaScript函数、方法、对象代码
2008/10/29 Javascript
JQUERY的属性选择符和自定义选择符使用方法(二)
2011/04/07 Javascript
jquery实现点击label的同时触发文本框点击事件的方法
2015/06/05 Javascript
BootstrapTable与KnockoutJS相结合实现增删改查功能【二】
2016/05/10 Javascript
前端学习笔记style,currentStyle,getComputedStyle的用法与区别
2016/05/28 Javascript
浅谈如何实现easyui的datebox格式化
2016/06/12 Javascript
Bootstrap整体框架之CSS12栅格系统
2016/12/15 Javascript
详解jQuery中ajax.load()方法
2017/01/25 Javascript
JavaScript设计模式之策略模式详解
2017/06/09 Javascript
vue项目中引入noVNC远程桌面的方法
2018/03/05 Javascript
通过JS运行机制的角度说说作用域
2019/03/12 Javascript
vue+elementUI动态生成面包屑导航教程
2019/11/04 Javascript
JavaScript实现拖拽效果
2020/03/16 Javascript
解决vuecli3中img src 的引入问题
2020/08/04 Javascript
Python 中pandas.read_excel详细介绍
2017/06/23 Python
python爬虫获取小区经纬度以及结构化地址
2018/12/30 Python
解决Python中定时任务线程无法自动退出的问题
2019/02/18 Python
Django  ORM 练习题及答案
2019/07/19 Python
学习Django知识点分享
2019/09/11 Python
pygame实现俄罗斯方块游戏(基础篇2)
2019/10/29 Python
django xadmin 管理器常用显示设置方式
2020/03/11 Python
使用python创建Excel工作簿及工作表过程图解
2020/05/27 Python
使用 prometheus python 库编写自定义指标的方法(完整代码)
2020/06/29 Python
索尼巴西商店:Sony巴西
2019/06/21 全球购物
您附近的水疗和健康场所:Spafinder(美国)
2019/07/05 全球购物
如何向接受结构参数的函数传入常数值
2016/02/17 面试题
法人任命书范本
2014/06/04 职场文书
2014领导班子四风问题对照检查材料思想汇报
2014/09/21 职场文书
详解缓存穿透击穿雪崩解决方案
2021/05/28 Redis