点餐小程序实战教程08-购物车功能开发

news/2024/7/20 2:46:16 标签: 小程序, 前端, 微搭, 低代码

目录

  • 1 创建购物车
  • 2 增加数量
  • 3 减少数量
  • 4 切换分类时回填数据
  • 5 显示购物车信息
  • 总结

我们上一篇搭建了点餐业务的数据初始化加载,本篇实现一下加入购物车的功能。在购物车设计的时候有两种方案,一种是使用数据表的方案,一种是使用变量的方案。

数据表方案的优点是持久化到数据源中,下一次打开小程序的时候还可以继续点餐。变量的方案是比较简单,不用和数据源有太多的交互。

1 创建购物车

打开我们的应用编辑器,在全局变量添加一个变量cartList
在这里插入图片描述

2 增加数量

接着我们实现一下增加数量的事件,在代码区点击+号增加一个自定义方法
在这里插入图片描述
方法的逻辑是将当前数据的count字段加一,并把记录加入到购物车中,如果是首次加入直接在数组中添加元素即可,如果已经存在我们就更新对应的元素,代码如下:

export default function({event, data}) {
   console.log(data.target)
   const record = data.target
   record.count++;
   if($w.app.dataset.state.cartList.length ===0){
      $w.app.dataset.state.cartList.push(record)
   }else{
      let flag = false
      $w.app.dataset.state.cartList.forEach(item=>{
         if(item._id == record._id){
            flag = true
            item.count = record.count
         }
      })
      if(!flag){
         $w.app.dataset.state.cartList.push(record)
      }
   }
}

代码的逻辑是先看购物车是不是空的,如果数组的长度为0表示购物车是空的,那我们直接调用数组的push方法将菜品放入购物车

如果购物车不为空,那么就去循环一下购物车,看当前选的商品放入购物车里没,条件是购物车的商品的标识等于我们选购商品的标识,加入了我们就更新购物车商品的数量,如果没加入我们就直接放入

在调用自定义方法时,需要传入参数,参数是我们当前这条记录
在这里插入图片描述

3 减少数量

增加的做好之后,我们要开发一下减少的功能。同样的在代码区增加一个自定义方法,命名为minus
在这里插入图片描述
减少的逻辑需要先判断一下当前的数量够不够减,不能出现负数,代码如下

export default function ({ event, data }) {
   const record = data.target
   if (record.count > 0) {
      record.count--;
   }

   if ($w.app.dataset.state.cartList.length === 0) {
      $w.app.dataset.state.cartList.push(record)
   } else {
      let flag = false
      $w.app.dataset.state.cartList.forEach(item => {
         if (item._id == record._id) {
            flag = true
            item.count = record.count
         }
      })
      if (!flag) {
         $w.app.dataset.state.cartList.push(record)
      }
   }
}

调用的时候也需要传入所在行的数据
在这里插入图片描述
还有一个逻辑是当数量减为0的时候我们要隐藏减号和文本组件,可以设置条件展示,加一个判断条件
在这里插入图片描述

4 切换分类时回填数据

目前代码存在的问题是如果我们选购了商品,如果切换分类的时候我们已经选择的信息就消失了,为了记住信息,我们在加载数据的时候要把购物车的信息再回填一下,修改我们的initMenuCount方法,添加如下代码

export default function({event, data}) {
   const list = event.detail.data
   console.log(list)
   $w.app.dataset.state.showlist_temp = list.map(item=>{
      const product = $w.app.dataset.state.cartList.find(v=>v._id==item._id)
      item.count = product?product.count:0
      return item
   })
}

这里event.detail.data可以获取原表格的数据,这个是从数据源查出来的,然后我们先是循环了原表格,调用了数组的map方法。在具体的每一条记录我们需要看一下购物车里的数据是否和当前表格一样,一样我们就把数量修改为购物车的数量。

最后处理好的数据我们在赋值回去,这样就起到了一个数据更新的作用。

5 显示购物车信息

我们还需要一个购物车显示的功能,显示总价,已经购买商品的数量。选中页面组件,添加一个普通容器,里边放入网格布局
在这里插入图片描述
修改一下网格布局的列,我们只需要两列
在这里插入图片描述
第一列添加一个图标和两个文本组件
在这里插入图片描述
切换到样式,设置布局模式为横向排列、垂直居中
在这里插入图片描述
第二列添加一个按钮
在这里插入图片描述
我们第一个文本要显示总价,总价的话从购物车求和就可以,绑定如下表达式

`${$w.app.dataset.state.cartList.reduce((total,current)=>{
    return total+(current.cpjg*current.count)
},0).toFixed(2)}`

这里用到了数组的求和方法,reduce需要两个参数,第一个是求和的方法,我们这里使用的是单价*数量进行累加,第二个参数是我们初始时的初值,我们设置为0

第二个文本要显示购买的数量,直接获取数组的长度即可,绑定如下表达式

`${$w.app.dataset.state.cartList.length}`

然后设置一下普通容器的定位设置成固定定位
在这里插入图片描述

总结

本篇我们实现了一下购物车的功能,涉及到添加到购物车,显示总价、购买的件数等逻辑。涉及到具体逻辑就需要对javascript有比较深入的掌握,否则很难实现功能,编程的基本功还是要扎实掌握的。


http://www.niftyadmin.cn/n/5078074.html

相关文章

JUC的线程池架构

🙈作者简介:练习时长两年半的Java up主 🙉个人主页:程序员老茶 🙊 ps:点赞👍是免费的,却可以让写博客的作者开心好久好久😎 📚系列专栏:Java全栈,…

Verilog generate

Verilog generate 文章目录 Verilog generategenerate用法generate-forgenerate-ifgenerate-case 应用分析1. 循环生成构造2. 条件生成构造3. 分层访问生成块 注意点例子 generate用法 关键字generate和endgenerate作为使用语法的起点,有三种衍生结构: …

SQL语句之in操作符

SQL语句之in操作符 用法简介适用场景例子 用法简介 IN是SQL中的一个操作符,用于筛选数据。它用于指定一个条件,该条件检查某个列中的值是否在给定的值列表中。 以下是IN操作符的基本语法: SELECT 列名 FROM 表名 WHERE 列名 IN (值列表…

【算法|双指针系列No.4】leetcode11. 盛最多水的容器

个人主页:兜里有颗棉花糖 欢迎 点赞👍 收藏✨ 留言✉ 加关注💓本文由 兜里有颗棉花糖 原创 收录于专栏【手撕算法系列专栏】【LeetCode】 🍔本专栏旨在提高自己算法能力的同时,记录一下自己的学习过程,希望…

LabVIEW玩转魔方

LabVIEW玩转魔方 使用LabVIEW创建一个3D魔方,并找出解谜题的秘密,给朋友留下深刻深刻的印象。游戏中内置的机制使每张脸都能独立转动,从而混合颜色。要解决难题,每个面必须是相同的纯色 魔方的奥秘在于它的简单性和不可解性。这是…

Unity脚本判断场景内物体是否为Root Prefab的方法

问题 由于如果不是根Prefab,是无法通过PrefabUtility.GetPrefabAssetPathOfNearestInstanceRoot(gameObject)获得的地址来进行修改后属性的存储的。 所以,如果脚本中需要对修改属性后的Prefabs进行保存,又要避开Prefabs下的part&#xff0c…

在Kubernetes中实现gRPC流量负载均衡

在尝试将gRPC服务部署到Kubernetes集群中时,一些用户(包括我)面临的挑战之一是实现适当的负载均衡。在深入了解如何平衡gRPC的方式之前,我们首先需要回答一个问题,即为什么需要平衡流量,如果Kubernetes已经…

带你一张图了解八种流行的网络协议

网络协议是在网络中两台计算机之间传输数据的标准方法。 本文将通过一张图详解 8 种流行的网络协议。 1、HTTP(超文本传输协议),HTTP 是一种用于获取 HTML 文档等资源的协议。它是 Web 上任何数据交换的基础,是一种客户端 - 服务…