91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序怎么實現點餐小程序購物車效果

發布時間:2022-03-09 10:00:27 來源:億速云 閱讀:213 作者:iii 欄目:開發技術

這篇文章主要講解了“小程序怎么實現點餐小程序購物車效果”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“小程序怎么實現點餐小程序購物車效果”吧!

自己的第一個點餐小程序,主要包括左右菜單聯動、點擊數量加減、菜單和購物車數量可以同步加減、購物車動畫等,純前端實現

大致的功能樣式如下圖展示:

      小程序怎么實現點餐小程序購物車效果

代碼塊

主要代碼塊:

  // 點擊左側分類切換右側菜品
  changeRightMenu: function (e) {
    var classify = e.target.dataset.id;// 獲取點擊項的id
    var foodList = this.data.foodList;
    var allFoodList = this.data.allFoodList;
    var newFoodList = [];
    if (classify == 0) {//選擇了全部選項
      this.setData({
        curNav: classify,
        foodList: allFoodList
      })
    } else { //選擇了其他選項
      for (var i in allFoodList) {
        if (allFoodList[i].catid == classify) {
          newFoodList.push(allFoodList[i])
        }
      }
      this.setData({
        // 右側菜單當前顯示第curNav項
        curNav: classify,
        foodList: newFoodList
      })
    }
  },

 // 購物車及菜單中增加數量
  addCount: function (e) {
    var id = e.currentTarget.dataset.id;[這里寫鏈接內容](http://download.csdn.net/download/m0_37543652/10019843%20%20%E6%BA%90%E7%A0%81%E4%B8%8B%E8%BD%BD%E5%9C%B0%E5%9D%80)
    var arr = wx.getStorageSync('cart') || [];
    var f = false;
    for (var i in this.data.foodList) {// 遍歷菜單找到被點擊的菜品,數量加1
      if (this.data.foodList[i].id == id) {
        this.data.foodList[i].quantity += 1;
        if (arr.length > 0) {
          for (var j in arr) {// 遍歷購物車找到被點擊的菜品,數量加1
            if (arr[j].id == id) {
              arr[j].quantity += 1;
              f = true;
              try {
                wx.setStorageSync('cart', arr)
              } catch (e) {
                console.log(e)
              }
              break;
            }
          }
          if (!f) {
            arr.push(this.data.foodList[i]);
          }
        } else {
          arr.push(this.data.foodList[i]);
        }
        try {
          wx.setStorageSync('cart', arr)
        } catch (e) {
          console.log(e)
        }
        break;
      }
    }

    this.setData({
      cartList: arr,
      foodList: this.data.foodList
    })
    this.getTotalPrice();
  },
  // 定義根據id刪除數組的方法
  removeByValue: function (array, val) {
    for (var i = 0; i < array.length; i++) {
      if (array[i].id == val) {
        array.splice(i, 1);
        break;
      }
    }
  },
  // 購物車減少數量
  minusCount: function (e) {
    var id = e.currentTarget.dataset.id;
    var arr = wx.getStorageSync('cart') || [];
    for (var i in this.data.foodList) {
      if (this.data.foodList[i].id == id) {
        this.data.foodList[i].quantity -= 1;
        if (this.data.foodList[i].quantity <= 0) {
          this.data.foodList[i].quantity = 0;
        }
        if (arr.length > 0) {
          for (var j in arr) {
            if (arr[j].id == id) {
              arr[j].quantity -= 1;
              if (arr[j].quantity <= 0) {
                this.removeByValue(arr, id)
              }
              if (arr.length <= 0) {
                this.setData({
                  foodList: this.data.foodList,
                  cartList: [],
                  totalNum: 0,
                  totalPrice: 0,
                })
                this.cascadeDismiss()
              }
              try {
                wx.setStorageSync('cart', arr)
              } catch (e) {
                console.log(e)
              }
            }
          }
        }
      }
    }
    this.setData({
      cartList: arr,
      foodList: this.data.foodList
    })
    this.getTotalPrice();
  },

感謝各位的閱讀,以上就是“小程序怎么實現點餐小程序購物車效果”的內容了,經過本文的學習后,相信大家對小程序怎么實現點餐小程序購物車效果這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

屯留县| 都兰县| 锡林郭勒盟| 蚌埠市| 鹤壁市| 噶尔县| 克东县| 读书| 彭山县| 海南省| 七台河市| 民丰县| 恩平市| 疏勒县| 棋牌| 香格里拉县| 绍兴县| 深圳市| 金沙县| 手游| 佛学| 河南省| 延寿县| 板桥市| 石林| 武乡县| 百色市| 德庆县| 凤山县| 达州市| 岳池县| 蛟河市| 织金县| 富阳市| 江达县| 安丘市| 嘉禾县| 潼南县| 客服| 枝江市| 云龙县|