微信小程序外賣(mài)選購(gòu)頁(yè)實(shí)現(xiàn)切換分類(lèi)與數(shù)量加減功能案例
本文實(shí)例講述了微信小程序外賣(mài)選購(gòu)頁(yè)實(shí)現(xiàn)切換分類(lèi)與數(shù)量加減功能。分享給大家供大家參考,具體如下:
關(guān)于微信小程序外賣(mài)界面實(shí)現(xiàn)選購(gòu)切換分類(lèi)與數(shù)量加減功能開(kāi)發(fā)步驟:
效果圖

實(shí)現(xiàn)以下功能
一、 點(diǎn)擊分類(lèi)項(xiàng),切換右邊的食品,并高亮自身
這個(gè)實(shí)現(xiàn)比較簡(jiǎn)單,給一個(gè)states數(shù)組,用于記錄每一項(xiàng)分類(lèi)的狀態(tài),點(diǎn)擊設(shè)為true,wxml渲染時(shí)三目運(yùn)算判斷即可。
categoryStates = categoryStates.map(function (item, i) {
if (index == i) {
item = true;
} else {
item = false;
}
return item;
});
相應(yīng)的wxml文件
class="{{categoryStates[index] ? 'category-item-active' : ''}}"
二、 加減按鈕
初始只有一個(gè)加號(hào)
點(diǎn)擊加號(hào)后,相應(yīng)商品數(shù)量+1,并出現(xiàn)減號(hào)
減至0時(shí),減號(hào)消失,連同數(shù)量值
設(shè)計(jì)數(shù)組結(jié)構(gòu)
cartData: {},它的鍵是Food表的objectId,值是數(shù)量。
以下是js代碼實(shí)現(xiàn)
add: function (e) {
// 所點(diǎn)商品id
var foodId = e.currentTarget.dataset.foodId;
console.log(foodId);
// 讀取目前購(gòu)物車(chē)數(shù)據(jù)
var cartData = that.data.cartData;
// 獲取當(dāng)前商品數(shù)量
var foodCount = cartData[foodId] ? cartData[foodId] : 0;
// 自增1后存回
cartData[foodId] = ++foodCount;
// 設(shè)值到data數(shù)據(jù)中
that.setData({
cartData: cartData
});
}
在wxml文件中綁定數(shù)據(jù)如下
<view class="stepper">
<!-- 減號(hào) -->
<view class="symbol subtract" wx:if="{{cartData[item.objectId]}}">-</view>
<!-- 數(shù)量 -->
<view class="value">{{cartData[item.objectId]}}</view>
<!-- 加號(hào) -->
<view class="symbol add" bindtap="add" data-food-id="{{item.objectId}}">+</view>
</view>
上述代碼中,通過(guò)wx:if判斷當(dāng)前商品的數(shù)量是否存在,無(wú)則不顯示減號(hào)按鈕;而在加號(hào)按鈕旁要顯示的數(shù)量就是{{cartData[item.objectId]}};點(diǎn)擊事件傳遞的foodId就是{{item.objectId}}
減法按鈕類(lèi)似
subtract: function (e) {
// 所點(diǎn)商品id
var foodId = e.currentTarget.dataset.foodId;
// 讀取目前購(gòu)物車(chē)數(shù)據(jù)
var cartData = that.data.cartData;
// 獲取當(dāng)前商品數(shù)量
var foodCount = cartData[foodId];
// 自減1
--foodCount;
// 減到零了就直接移除
if (foodCount == 0) {
delete cartData[foodId]
} else {
cartData[foodId] = foodCount;
}
// 設(shè)值到data數(shù)據(jù)中
that.setData({
cartData: cartData
});
}
減法與加法基本類(lèi)似,值得一提的是,減法要判斷非負(fù)的合法性,所以將自減至零時(shí),直接將元素通過(guò)delete操作移除,省去后續(xù)提交購(gòu)物車(chē)遍歷匯總的非零判斷的煩瑣。
Todo List
購(gòu)物車(chē)動(dòng)畫(huà)
購(gòu)物車(chē)邏輯
提交數(shù)據(jù)到后端存儲(chǔ)
希望本文所述對(duì)大家微信小程序開(kāi)發(fā)有所幫助。
相關(guān)文章
給localStorage設(shè)置一個(gè)過(guò)期時(shí)間的方法分享
我們都知道localStorage不主動(dòng)刪除,永遠(yuǎn)不會(huì)銷(xiāo)毀,那么如何設(shè)置localStorage的過(guò)期時(shí)間呢?下面這篇文章主要給大家介紹了關(guān)于如何給localStorage設(shè)置一個(gè)過(guò)期時(shí)間的相關(guān)資料,需要的朋友可以參考下2018-11-11
Android中Okhttp3實(shí)現(xiàn)上傳多張圖片同時(shí)傳遞參數(shù)
本篇文章主要介紹了Android中Okhttp3實(shí)現(xiàn)上傳多張圖片同時(shí)傳遞參數(shù) ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02
javascript使用eval或者new Function進(jìn)行語(yǔ)法檢查
使用代碼來(lái)實(shí)現(xiàn)分析代碼的語(yǔ)法,這是一件極其痛苦的事情。簡(jiǎn)單的解決辦法是:使用腳本引擎自己的語(yǔ)法檢查,比方說(shuō)eval( ) 或者new Function( )。2010-10-10
javascript動(dòng)態(tài)創(chuàng)建鏈接的方法
這篇文章主要介紹了javascript動(dòng)態(tài)創(chuàng)建鏈接的方法,涉及javascript動(dòng)態(tài)操作頁(yè)面元素的技巧,需要的朋友可以參考下2015-05-05
JavaScript數(shù)組去重和扁平化函數(shù)介紹
這篇文章主要介紹了JavaScript數(shù)組去重和扁平化函數(shù),數(shù)組扁平化又稱(chēng)數(shù)組降維,下面文章圍繞數(shù)組去重和扁平化函數(shù)得相關(guān)資料展開(kāi)內(nèi)容,需要的朋友可以參考一下2021-12-12
基于JavaScript實(shí)現(xiàn)雪花許愿墻特效
新的一年就要到了,你一定有很多想許下的愿望吧!今天小編就為大家?guī)?lái)了一個(gè)基于Html+CSS+JavaScript實(shí)現(xiàn)的帶雪花的許愿墻特效,需要的可以了解一下2022-01-01

