国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 微信小程序 小程序開發(fā) 微信小程序怎么實(shí)現(xiàn)購物車功能?(方法介紹)

微信小程序怎么實(shí)現(xiàn)購物車功能?(方法介紹)

May 01, 2020 am 09:44 AM
小程序

微信小程序怎么實(shí)現(xiàn)購物車功能?下面本篇文章給大家介紹一下微信小程序?qū)崿F(xiàn)購物車功能的方法。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

微信小程序怎么實(shí)現(xiàn)購物車功能?(方法介紹)

不管是商城類還是餐飲類小程序,都需要通過下單完成交易,因此都需要有一個加入購物車的操作。以往購物車功能基本都是通過大量的?DOM?操作來實(shí)現(xiàn),由于小程序不是基于web以此無法創(chuàng)建DOM。微信小程序?qū)崿F(xiàn)購物車功能其實(shí)跟?vue.js?的用法非常像。

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

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

單個商品購買數(shù)量的增加和減少

刪除商品。當(dāng)購物車為空時,頁面會變?yōu)榭召徫镘嚨牟季?/p>

根據(jù)設(shè)計(jì)圖,我們可以先實(shí)現(xiàn)靜態(tài)頁面。接下來,再看看一個購物車需要什么樣的數(shù)據(jù)。

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

然后左下角的全選,需要一個字段(selectAllStatus)表示是否全選了

右下角的總價(totalPrice)

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

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

初始化代碼:

Page({
    data: {
        carts:[],               // 購物車列表
        hasList:false,          // 列表是否有數(shù)據(jù)
       totalPrice:0,           // 總價,初始為0
       selectAllStatus:true    // 全選狀態(tài),默認(rèn)全選
    },
    onShow() {
        this.setData({
          hasList:true,        // 既然有數(shù)據(jù)了,那設(shè)為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}
          ]
        });
      },
})

購物車列表數(shù)據(jù)我們一般是通過請求服務(wù)器拿到的數(shù)據(jù),所以我們放在生命周期函數(shù)里給carts賦值。想到每次進(jìn)到購物車都要獲取購物車的最新狀態(tài),而onLoad和onReady只在初始化的時候執(zhí)行一次,所以我需要把請求放在onShow函數(shù)里。

計(jì)算總價

總價?=?選中的商品1的 價格?*?數(shù)量? ?選中的商品2的價格?*?數(shù)量? ?…

根據(jù)公式,可以得到

getTotalPrice() {
    let carts =this.data.carts;                  // 獲取購物車列表
    let total = 0;
    for(let i = 0;i<carts.length; i++)="{        =" 循環(huán)列表得到每個數(shù)據(jù)<="span=" style=";padding: 0px">
        if(carts[i].selected){                   // 判斷選中才會計(jì)算價格
            total +=carts[i].num * carts[i].price;     // 所有價格加起來
        }
    }
    this.setData({                                // 最后賦值到data中渲染到頁面
        carts: carts,
        totalPrice:total.toFixed(2)
    });
}

頁面中的其他操作會導(dǎo)致總價格變化的都需要調(diào)用該方法。

選擇事件

點(diǎn)擊時選中,再點(diǎn)擊又變成沒選中狀態(tài),其實(shí)就是改變?selected?字段。通過?data-index=”{{index}}” 把當(dāng)前商品在列表數(shù)組中的下標(biāo)傳給事件。

selectList(e) {
    const index =e.currentTarget.dataset.index;    // 獲取data- 傳進(jìn)來的index
    let carts =this.data.carts;                    // 獲取購物車列表
    const selected =carts[index].selected;         // 獲取當(dāng)前商品的選中狀態(tài)
    carts[index].selected= !selected;              // 改變狀態(tài)
    this.setData({
        carts: carts
    });
   this.getTotalPrice();                           // 重新獲取總價
}

全選事件

全選就是根據(jù)全選狀態(tài)?selectAllStatus?去改變每個商品的?selected

selectAll(e) {
    let selectAllStatus =this.data.selectAllStatus;    // 是否全選狀態(tài)
    selectAllStatus =!selectAllStatus;
    let carts =this.data.carts;
 
    for (let i = 0; i< carts.length; i++) {
        carts[i].selected = selectAllStatus;            // 改變所有商品狀態(tài)
    }
    this.setData({
        selectAllStatus:selectAllStatus,
        carts: carts
    });
   this.getTotalPrice();                               // 重新獲取總價
}

增減數(shù)量

點(diǎn)擊 號,num加1,點(diǎn)擊-號,如果num > 1,則減1

// 增加數(shù)量
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();
},
// 減少數(shù)量
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();
}

刪除商品

點(diǎn)擊刪除按鈕則從購物車列表中刪除當(dāng)前元素,刪除之后如果購物車為空,改變購物車為空標(biāo)識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              // 修改標(biāo)識為false,顯示購物車為空頁面
        });
    }else{                              // 如果不為空
       this.getTotalPrice();           //重新計(jì)算總價格
    }  
}

小程序購物車功能開發(fā)把各個功能模塊拆分單獨(dú)進(jìn)行開發(fā),基本與網(wǎng)頁端和APP端開發(fā)思路如出一轍。雖然一個購物車功能比較簡單,但是里面涉及到微信小程序的知識點(diǎn)還是比較多的。

推薦:《小程序開發(fā)教程

以上是微信小程序怎么實(shí)現(xiàn)購物車功能?(方法介紹)的詳細(xì)內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

使用Python開發(fā)微信小程序 使用Python開發(fā)微信小程序 Jun 17, 2023 pm 06:34 PM

隨著移動互聯(lián)網(wǎng)技術(shù)和智能手機(jī)的普及,微信成為了人們生活中不可或缺的一個應(yīng)用。而微信小程序則讓人們可以在不需要下載安裝應(yīng)用的情況下,直接使用小程序來解決一些簡單的需求。本文將介紹如何使用Python來開發(fā)微信小程序。一、準(zhǔn)備工作在使用Python開發(fā)微信小程序之前,需要安裝相關(guān)的Python庫。這里推薦使用wxpy和itchat這兩個庫。wxpy是一個微信機(jī)器

實(shí)現(xiàn)微信小程序中的卡片翻轉(zhuǎn)特效 實(shí)現(xiàn)微信小程序中的卡片翻轉(zhuǎn)特效 Nov 21, 2023 am 10:55 AM

實(shí)現(xiàn)微信小程序中的卡片翻轉(zhuǎn)特效在微信小程序中,實(shí)現(xiàn)卡片翻轉(zhuǎn)特效是一種常見的動畫效果,可以提升用戶體驗(yàn)和界面交互的吸引力。下面將具體介紹如何在微信小程序中實(shí)現(xiàn)卡片翻轉(zhuǎn)的特效,并提供相關(guān)代碼示例。首先,需要在小程序的頁面布局文件中定義兩個卡片元素,一個用于顯示正面內(nèi)容,一個用于顯示背面內(nèi)容,具體示例代碼如下:&lt;!--index.wxml--&gt;&l

支付寶上線'漢字拾光-生僻字”小程序,用于征集、補(bǔ)充生僻字庫 支付寶上線'漢字拾光-生僻字”小程序,用于征集、補(bǔ)充生僻字庫 Oct 31, 2023 pm 09:25 PM

本站10月31日消息,今年5月27日,螞蟻集團(tuán)宣布啟動“漢字拾光計(jì)劃”,最近又迎來新進(jìn)展:支付寶上線“漢字拾光-生僻字”小程序,用于向社會征集生僻字,補(bǔ)充生僻字庫,同時提供不同的生僻字輸入體驗(yàn),以幫助完善支付寶內(nèi)的生僻字輸入方法。目前,用戶搜索“漢字拾光”、“生僻字”等關(guān)鍵詞就可以進(jìn)入“生僻字”小程序。在小程序里,用戶可以提交尚未被系統(tǒng)識別錄入的生僻字圖片,支付寶工程師在確認(rèn)后,將會對字庫進(jìn)行補(bǔ)錄入。本站注意到,用戶還可以在小程序體驗(yàn)最新的拆字輸入法,這一輸入法針對讀音不明確的生僻字設(shè)計(jì)。用戶拆

小程序能用react嗎 小程序能用react嗎 Dec 29, 2022 am 11:06 AM

小程序能用react,其使用方法:1、基于“react-reconciler”實(shí)現(xiàn)一個渲染器,生成一個DSL;2、創(chuàng)建一個小程序組件,去解析和渲染DSL;3、安裝npm,并執(zhí)行開發(fā)者工具中的構(gòu)建npm;4、在自己的頁面中引入包,再利用api即可完成開發(fā)。

uniapp如何實(shí)現(xiàn)小程序和H5的快速轉(zhuǎn)換 uniapp如何實(shí)現(xiàn)小程序和H5的快速轉(zhuǎn)換 Oct 20, 2023 pm 02:12 PM

uniapp如何實(shí)現(xiàn)小程序和H5的快速轉(zhuǎn)換,需要具體代碼示例近年來,隨著移動互聯(lián)網(wǎng)的發(fā)展和智能手機(jī)的普及,小程序和H5成為了不可或缺的應(yīng)用形式。而uniapp作為一個跨平臺的開發(fā)框架,可以在一套代碼的基礎(chǔ)上,快速實(shí)現(xiàn)小程序和H5的轉(zhuǎn)換,大大提高了開發(fā)效率。本文將介紹uniapp如何實(shí)現(xiàn)小程序和H5的快速轉(zhuǎn)換,并給出具體的代碼示例。一、uniapp簡介unia

教你如何在小程序中用公眾號模板消息(附詳細(xì)思路) 教你如何在小程序中用公眾號模板消息(附詳細(xì)思路) Nov 04, 2022 pm 04:53 PM

本篇文章給大家?guī)砹岁P(guān)于微信小程序的相關(guān)問題,其中主要介紹了如何在小程序中用公眾號模板消息,下面一起來看一下,希望對大家有幫助。

用Python編寫簡單的聊天程序教程 用Python編寫簡單的聊天程序教程 May 08, 2023 pm 06:37 PM

實(shí)現(xiàn)思路x01服務(wù)端的建立首先,在服務(wù)端,使用socket進(jìn)行消息的接受,每接受一個socket的請求,就開啟一個新的線程來管理消息的分發(fā)與接受,同時,又存在一個handler來管理所有的線程,從而實(shí)現(xiàn)對聊天室的各種功能的處理x02客戶端的建立客戶端的建立就要比服務(wù)端簡單多了,客戶端的作用只是對消息的發(fā)送以及接受,以及按照特定的規(guī)則去輸入特定的字符從而實(shí)現(xiàn)不同的功能的使用,因此,在客戶端這里,只需要去使用兩個線程,一個是專門用于接受消息,一個是專門用于發(fā)送消息的至于為什么不用一個呢,那是因?yàn)?只

PHP與小程序的地理位置定位與地圖顯示 PHP與小程序的地理位置定位與地圖顯示 Jul 04, 2023 pm 04:01 PM

PHP與小程序的地理位置定位與地圖顯示地理位置定位與地圖顯示在現(xiàn)代科技中已經(jīng)成為了必備的功能之一。隨著移動設(shè)備的普及,人們對于定位和地圖顯示的需求也越來越高。在開發(fā)過程中,PHP和小程序是常見的兩種技術(shù)選擇。本文將為大家介紹PHP與小程序中的地理位置定位與地圖顯示的實(shí)現(xiàn)方法,并附上相應(yīng)的代碼示例。一、PHP中的地理位置定位在PHP中,我們可以使用第三方地理位

See all articles