国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 熱點 > 微信 > 正文

微信小程序外賣選購頁實現切換分類與數量加減功能案例

2024-07-22 01:19:13
字體:
來源:轉載
供稿:網友

本文實例講述了微信小程序外賣選購頁實現切換分類與數量加減功能。分享給大家供大家參考,具體如下:

關于微信小程序外賣界面實現選購切換分類與數量加減功能開發步驟:

效果圖

實現以下功能

一、 點擊分類項,切換右邊的食品,并高亮自身

這個實現比較簡單,給一個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
購物車動畫
購物車邏輯
提交數據到后端存儲

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 习水县| 资源县| 丰镇市| 天长市| 保定市| 久治县| 桃园县| 闽清县| 共和县| 阳谷县| 唐山市| 云南省| 天长市| 新乐市| 寿阳县| 石泉县| 棋牌| 勐海县| 晴隆县| 庆元县| 潮安县| 抚州市| 鲁甸县| 岗巴县| 吴堡县| 榆林市| 紫阳县| 楚雄市| 恩施市| 孝感市| 剑河县| 三门峡市| 绥阳县| 长丰县| 镇远县| 杭锦后旗| 湘西| 远安县| 诸暨市| 远安县| 奉贤区|