时间:2021-05-18
本文实例讲述了微信小程序外卖选购页实现切换分类与数量加减功能。分享给大家供大家参考,具体如下:
关于微信小程序外卖界面实现选购切换分类与数量加减功能开发步骤:
效果图
实现以下功能
一、 点击分类项,切换右边的食品,并高亮自身
这个实现比较简单,给一个states数组,用于记录每一项分类的状态,点击设为true,wxml渲染时三目运算判断即可。
categoryStates = categoryStates.map(function (item, i) {if (index == i) {item = true;} else {item = false;}return item;});相应的wxml文件
class="{{categoryStates[index] ? 'category-item-active' : ''}}"二、 加减按钮
初始只有一个加号
点击加号后,相应商品数量+1,并出现减号
减至0时,减号消失,连同数量值
设计数组结构
cartData: {},它的键是Food表的objectId,值是数量。
以下是js代码实现
add: function (e) {// 所点商品idvar foodId = e.currentTarget.dataset.foodId;console.log(foodId);// 读取目前购物车数据var cartData = that.data.cartData;// 获取当前商品数量var foodCount = cartData[foodId] ? cartData[foodId] : 0;// 自增1后存回cartData[foodId] = ++foodCount;// 设值到data数据中that.setData({cartData: cartData});}在wxml文件中绑定数据如下
<view class="stepper"><!-- 减号 --><view class="symbol subtract" wx:if="{{cartData[item.objectId]}}">-</view><!-- 数量 --><view class="value">{{cartData[item.objectId]}}</view><!-- 加号 --><view class="symbol add" bindtap="add" data-food-id="{{item.objectId}}">+</view></view>上述代码中,通过wx:if判断当前商品的数量是否存在,无则不显示减号按钮;而在加号按钮旁要显示的数量就是{{cartData[item.objectId]}};点击事件传递的foodId就是{{item.objectId}}
减法按钮类似
subtract: function (e) {// 所点商品idvar foodId = e.currentTarget.dataset.foodId;// 读取目前购物车数据var cartData = that.data.cartData;// 获取当前商品数量var foodCount = cartData[foodId];// 自减1--foodCount;// 减到零了就直接移除if (foodCount == 0) {delete cartData[foodId]} else {cartData[foodId] = foodCount;}// 设值到data数据中that.setData({cartData: cartData});}减法与加法基本类似,值得一提的是,减法要判断非负的合法性,所以将自减至零时,直接将元素通过delete操作移除,省去后续提交购物车遍历汇总的非零判断的烦琐。
Todo List
购物车动画
购物车逻辑
提交数据到后端存储
希望本文所述对大家微信小程序开发有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
微信小程序,这里实现购物车功能的小demo,有需要此功能的朋友可以参考下。摘要:加减商品数量,汇总价格,全选与全不选设计思路:一、从网络上传入以下Json数据格
续上一篇的文章:微信小程序之购物数量加减——微信小程序实战商城系列(3)所提及的购物数量的加减,现在说说商品属性值联动选择。为了让同学们有个直观的了解,到电商网
微信小程序slider的简单实例实现效果图:微信小程序slider应用,可加减的slider控制{{v.name}}-+页面结构Page({data:{cont
微信小程序Tab页切换更新数据微信小程序还处于内测阶段,最不方便的莫过于官方在不停的更新,前几天写的功能隔个几天忽然发现不能用了_(:зゝ∠)_功能需求如下:我
就在昨天,微信宣布了微信小程序开发者工具新增“云开发”功能下载最新的开发者工具,现在无需服务器即可实现小程序的快速迭代!分类功能和搜素功能的效果图1.首页分类功