微信小程序?qū)崿F(xiàn)購(gòu)物車代碼實(shí)例詳解
其實(shí)購(gòu)物車都是類似的實(shí)現(xiàn)方法,只不過(guò)小程序是有他的數(shù)據(jù)層和業(yè)務(wù)層,在這里把之前的做法記錄一下,分享出來(lái)也希望能給需要的小伙伴帶來(lái)參考價(jià)值在最開(kāi)始的時(shí)候先從本地存儲(chǔ)中獲取購(gòu)物車數(shù)據(jù),因?yàn)槲覀儠?huì)切換頁(yè)面 在頁(yè)面切換的過(guò)程中需要實(shí)時(shí)重新加載購(gòu)物車的數(shù)據(jù),所以我們把獲取的方法寫(xiě)在onShow中,而不是onLoad中:
onShow: function () {
const cart = wx.getStorageSync("cart");
let address = wx.getStorageSync("address") ;
console.log(address);
this.setData({
address, cart
})
this.loadCarts();
this.countAll();
}
點(diǎn)擊按鈕更改購(gòu)物車的數(shù)量:
handleNumEdit(e) {
const { operator, goodsid } = e.target.dataset;
let { cart } = this.data;
cart[goodsid].count += (+operator);
if (cart[goodsid].count < 1) {
cart[goodsid].count = 1;
wx.showModal({
title: '提示',
content: '您確定要?jiǎng)h除嗎',
showCancel: true,
cancelText: '取消',
cancelColor: '#000000',
confirmText: '確定',
confirmColor: '#3CC51F',
success: (result) => {
if (result.confirm) {
delete cart[goodsid];
this.loadCarts();
this.countAll();
} else {
}
}
});
} else if (cart[goodsid].count > cart[goodsid].goods_number) {
cart[goodsid].count = cart[goodsid].goods_number;
wx.showToast({
title: '沒(méi)有庫(kù)存了',
icon: 'none',
duration: 1500,
mask: true
});
}
this.loadCarts();
this.countAll();
}
加載購(gòu)物車數(shù)據(jù)的方法:
data: {
cart: {},
address: {},
totalPrice: 0,
categoryLength: 0,
isAllChecked: true
},
單個(gè)商品被選中時(shí)觸發(fā):
loadCarts() {
let { cart } = this.data;
let isAllChecked = true;
for (const key in cart) {
if (cart.hasOwnProperty(key)) {
const element = cart[key];
if (!element.isChecked) {
isAllChecked = false;
break;
}
}
}
this.setData({
cart,
isAllChecked
});
},
全選和反選觸發(fā)的事件:
handleItemChecked(e) {
let { goodsid } = e.target.dataset;
let { cart } = this.data;
let { isChecked } = cart[goodsid];
cart[goodsid].isChecked = !isChecked;
let checkedLength = 0;
for (const key in cart) {
if (cart.hasOwnProperty(key)) {
if (cart[key].isChecked) {
checkedLength++;
}
}
}
const isAllChecked = checkedLength == Object.keys(cart).length;
this.countAll();
this.setData({
isAllChecked
})
},
點(diǎn)擊結(jié)算時(shí)觸發(fā):
handleItemAllChecked() {
let { isAllChecked } = this.data;
let { cart } = this.data;
isAllChecked = !isAllChecked;
for (const key in cart) {
if (cart.hasOwnProperty(key)) {
cart[key].isChecked = isAllChecked;
}
}
this.setData({
isAllChecked,
cart
})
this.countAll();
},
純js代碼,可能有一定小程序代碼經(jīng)驗(yàn)的會(huì)看得輕松一點(diǎn)。以上便可以實(shí)現(xiàn)在對(duì)購(gòu)物車的商品進(jìn)行加減和全選與反選,以及對(duì)商品進(jìn)行數(shù)量合計(jì)并計(jì)算價(jià)格。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 微信小程序 購(gòu)物車簡(jiǎn)單實(shí)例
- 微信小程序?qū)崙?zhàn)篇之購(gòu)物車的實(shí)現(xiàn)代碼示例
- 微信小程序?qū)崿F(xiàn)購(gòu)物車功能
- 微信小程序?qū)崿F(xiàn)多選框全選與反全選及購(gòu)物車中刪除選中的商品功能
- 微信小程序之購(gòu)物車功能
- 微信小程序購(gòu)物車、父子組件傳值及calc的注意事項(xiàng)總結(jié)
- 微信小程序?qū)崿F(xiàn)簡(jiǎn)單購(gòu)物車功能
- 微信小程序利用swiper+css實(shí)現(xiàn)購(gòu)物車商品刪除功能
- 微信小程序?qū)崿F(xiàn)加入購(gòu)物車滑動(dòng)軌跡
- 微信小程序?qū)崿F(xiàn)簡(jiǎn)單購(gòu)物車小功能
相關(guān)文章
el-date-picker 如何限制選擇六個(gè)月內(nèi)的日期
這篇文章主要介紹了el-date-picker 如何限制選擇六個(gè)月內(nèi)的日期,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-07-07
prefers-color-scheme設(shè)置檢測(cè)系統(tǒng)主題色
這篇文章主要為大家介紹了prefers-color-scheme設(shè)置檢測(cè)系統(tǒng)主題色實(shí)例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
簡(jiǎn)單實(shí)現(xiàn)js菜單欄切換效果
這篇文章主要教大家如何簡(jiǎn)單實(shí)現(xiàn)js菜單欄切換效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03
微信小程序?qū)崿F(xiàn)運(yùn)動(dòng)步數(shù)排行功能(可刪除)
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)運(yùn)動(dòng)步數(shù)排行功能(可刪除),實(shí)現(xiàn)代碼也很簡(jiǎn)單,需要的朋友可以參考下2018-07-07
微信小程序?qū)崿F(xiàn)添加手機(jī)聯(lián)系人功能示例
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)添加手機(jī)聯(lián)系人功能,結(jié)合實(shí)例形式分析了微信小程序添加聯(lián)系人的具體步驟,包括布局與邏輯實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-11-11
簡(jiǎn)單快速的實(shí)現(xiàn)js計(jì)算器功能
這篇文章主要教大家如何快速簡(jiǎn)單的實(shí)現(xiàn)js計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-08-08

