欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2019年01月15日 08:42:54   作者:第九程序  
這篇文章主要介紹了微信小程序外賣選購頁實現切換分類與數量加減功能,結合具體實例形式分析了微信小程序狀態(tài)記錄、判定及數值運算相關操作技巧,需要的朋友可以參考下

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

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

效果圖

實現以下功能

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

這個實現比較簡單,給一個states數組,用于記錄每一項分類的狀態(tài),點擊設為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) {
// 所點商品id
var 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) {
// 所點商品id
var 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操作移除,省去后續(xù)提交購物車遍歷匯總的非零判斷的煩瑣。

Todo List
購物車動畫
購物車邏輯
提交數據到后端存儲

希望本文所述對大家微信小程序開發(fā)有所幫助。

相關文章

  • 給localStorage設置一個過期時間的方法分享

    給localStorage設置一個過期時間的方法分享

    我們都知道localStorage不主動刪除,永遠不會銷毀,那么如何設置localStorage的過期時間呢?下面這篇文章主要給大家介紹了關于如何給localStorage設置一個過期時間的相關資料,需要的朋友可以參考下
    2018-11-11
  • Android中Okhttp3實現上傳多張圖片同時傳遞參數

    Android中Okhttp3實現上傳多張圖片同時傳遞參數

    本篇文章主要介紹了Android中Okhttp3實現上傳多張圖片同時傳遞參數 ,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • javascript使用eval或者new Function進行語法檢查

    javascript使用eval或者new Function進行語法檢查

    使用代碼來實現分析代碼的語法,這是一件極其痛苦的事情。簡單的解決辦法是:使用腳本引擎自己的語法檢查,比方說eval( ) 或者new Function( )。
    2010-10-10
  • layui按條件隱藏表格列的實例

    layui按條件隱藏表格列的實例

    今天小編就為大家分享一篇layui按條件隱藏表格列的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • javascript動態(tài)創(chuàng)建鏈接的方法

    javascript動態(tài)創(chuàng)建鏈接的方法

    這篇文章主要介紹了javascript動態(tài)創(chuàng)建鏈接的方法,涉及javascript動態(tài)操作頁面元素的技巧,需要的朋友可以參考下
    2015-05-05
  • JavaScript數組去重和扁平化函數介紹

    JavaScript數組去重和扁平化函數介紹

    這篇文章主要介紹了JavaScript數組去重和扁平化函數,數組扁平化又稱數組降維,下面文章圍繞數組去重和扁平化函數得相關資料展開內容,需要的朋友可以參考一下
    2021-12-12
  • Webpack如何引入bootstrap的方法

    Webpack如何引入bootstrap的方法

    本篇文章主要介紹了Webpack如何引入bootstrap的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • 基于JavaScript實現雪花許愿墻特效

    基于JavaScript實現雪花許愿墻特效

    新的一年就要到了,你一定有很多想許下的愿望吧!今天小編就為大家?guī)砹艘粋€基于Html+CSS+JavaScript實現的帶雪花的許愿墻特效,需要的可以了解一下
    2022-01-01
  • js 控制頁面跳轉的5種方法

    js 控制頁面跳轉的5種方法

    這篇文章介紹了js 控制頁面跳轉的5種方法,有需要的朋友可以參考一下
    2013-09-09
  • javascript使用鏈接跨域下載圖片

    javascript使用鏈接跨域下載圖片

    這篇文章主要介紹了javascript使用鏈接跨域下載圖片,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評論