搜尋
首頁微信小程式小程式開發微信小程式怎麼實現購物車功能? (方法介紹)

微信小程式怎麼實現購物車功能?以下這篇文章為大家介紹微信小程式實現購物車功能的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

微信小程式怎麼實現購物車功能? (方法介紹)

不管是商城類還是餐飲類小程序,都需要透過下單完成交易,因此都需要有一個加入購物車的操作。以往購物車功能基本上都是透過大量的 DOM 操作來實現,由於小程式不是基於web以此無法創建DOM。 微信小程式實作購物車功能其實跟 vue.js 的用法很像。

先來弄清楚購物車的需求。

單選、全選和取消,而且會隨著選取的商品計算出總價

單一商品購買數量的增加和減少

刪除商品。當購物車為空時,頁面會變成空購物車的佈局

根據設計圖,我們可以先實作靜態頁面。接下來,再看看一個購物車需要什麼樣的數據。

首先是一個商品列表(carts),列表裡的單品需要:商品圖(image),商品名(title),單價(price),數量(num),是否選中(selected),商品id(id)

接著左下角的全選,需要一個欄位(selectAllStatus)表示是否全選了

#右下角的總價(totalPrice)

最後需要知道購物車是否為空(hasList)

知道了需要這些數據,在頁面初始化的時候我們先定義好這些。

初始化程式碼:

Page({
    data: {
        carts:[],               // 购物车列表
        hasList:false,          // 列表是否有数据
       totalPrice:0,           // 总价,初始为0
       selectAllStatus:true    // 全选状态,默认全选
    },
    onShow() {
        this.setData({
          hasList:true,        // 既然有数据了,那设为true吧
          carts:[
            {id:1,title:\'新鲜芹菜 半斤\',image:\'/image/s5.png\',num:4,price:0.01,selected:true},
            {id:2,title:\'素米 500g\',image:\'/image/s6.png\',num:1,price:0.03,selected:true}
          ]
        });
      },
})

購物車列表資料我們一般是透過請求伺服器拿到的數據,所以我們放在生命週期函數裡給carts賦值。想到每次進到購物車都要獲取購物車的最新狀態,而onLoad和onReady只在初始化的時候執行一次,所以我需要把請求放在onShow函數裡。

計算總價

總價 = 選取的商品1的價格 * 數量   選取的商品2的價格 * 數量   …

根據公式,可以得到

getTotalPrice() {
    let carts =this.data.carts;                  // 获取购物车列表
    let total = 0;
    for(let i = 0;i<carts.length; i++)="{        =" 循环列表得到每个数据<="span=" style=";padding: 0px">
        if(carts[i].selected){                   // 判断选中才会计算价格
            total +=carts[i].num * carts[i].price;     // 所有价格加起来
        }
    }
    this.setData({                                // 最后赋值到data中渲染到页面
        carts: carts,
        totalPrice:total.toFixed(2)
    });
}

頁面中的其他操作會導致總價格變化的都需要呼叫該方法。

選擇事件

點擊時選中,再點選又變成沒選中狀態,其實就是改變 selected 欄位。透過 data-index=”{{index}}” 把目前商品在列表數組中的下標傳給事件。

selectList(e) {
    const index =e.currentTarget.dataset.index;    // 获取data- 传进来的index
    let carts =this.data.carts;                    // 获取购物车列表
    const selected =carts[index].selected;         // 获取当前商品的选中状态
    carts[index].selected= !selected;              // 改变状态
    this.setData({
        carts: carts
    });
   this.getTotalPrice();                           // 重新获取总价
}

全選事件

全選就是依照全選狀態 selectAllStatus 改變每個商品的 selected

selectAll(e) {
    let selectAllStatus =this.data.selectAllStatus;    // 是否全选状态
    selectAllStatus =!selectAllStatus;
    let carts =this.data.carts;
 
    for (let i = 0; i< carts.length; i++) {
        carts[i].selected = selectAllStatus;            // 改变所有商品状态
    }
    this.setData({
        selectAllStatus:selectAllStatus,
        carts: carts
    });
   this.getTotalPrice();                               // 重新获取总价
}

增加數量

點選號,num加1,點選-號,如果num > 1,則減1

// 增加数量
addCount(e) {
    const index =e.currentTarget.dataset.index;
    let carts =this.data.carts;
    let num =carts[index].num;
    num = num + 1;
    carts[index].num =num;
    this.setData({
      carts: carts
    });
    this.getTotalPrice();
},
// 减少数量
minusCount(e) {
    const index =e.currentTarget.dataset.index;
    let carts =this.data.carts;
    let num =carts[index].num;
    if(num <= 1){
      return false;
    }
    num = num - 1;
    carts[index].num =num;
    this.setData({
      carts: carts
    });
    this.getTotalPrice();
}

刪除商品

點擊刪除按鈕則從購物車清單中刪除目前元素,刪除之後如果購物車為空,改變購物車為空標識hasList為false

deleteList(e) {
    const index =e.currentTarget.dataset.index;
    let carts =this.data.carts;
   carts.splice(index,1);             // 删除购物车列表里这个商品
    this.setData({
        carts: carts
    });
   if(!carts.length){                 // 如果购物车为空
        this.setData({
            hasList:false              // 修改标识为false,显示购物车为空页面
        });
    }else{                              // 如果不为空
       this.getTotalPrice();           //重新计算总价格
    }  
}

小程式購物車功能開發把各個功能模組拆分單獨進行開發,基本上與網頁端及APP端開發思路如出一轍。雖然一個購物車功能比較簡單,但是裡面牽涉到微信小程式的知識點還是比較多的。

推薦:《小程式開發教學

以上是微信小程式怎麼實現購物車功能? (方法介紹)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:即速资讯。如有侵權,請聯絡admin@php.cn刪除

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境