最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
微信小程序商城開發(fā)之怎樣實現(xiàn)商品加入購物車功能

這篇文章將為大家詳細講解有關(guān)微信小程序商城開發(fā)之怎樣實現(xiàn)商品加入購物車功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)公司主要從事成都做網(wǎng)站、成都網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)坡頭,十余年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575

看效果

微信小程序商城開發(fā)之怎樣實現(xiàn)商品加入購物車功能

購物車.gif

開發(fā)計劃

1、商品詳情頁將商品信息放入緩存
2、購物車頁面讀取緩存獲取商品信息
3、購物車商品計算和刪除緩存商品

一、商品詳情頁將商品信息放入緩存

detail.wxml

確定

綁定bindtap事件將商品加入購物車。

detail.js

/**
   * 加入購物車
   */
  addCar: function (e) {    
    var goods = this.data.goods;
    goods.isSelect=false;    
    var count = this.data.goods.count;    
    var title = this.data.goods.title;    
    if (title.length > 13) {
      goods.title = title.substring(0, 13) + '...';
    }    
    // 獲取購物車的緩存數(shù)組(沒有數(shù)據(jù),則賦予一個空數(shù)組)  
    var arr = wx.getStorageSync('cart') || [];    
    console.log("arr,{}", arr);    
    if (arr.length > 0) {      
        // 遍歷購物車數(shù)組  
      for (var j in arr) {        
        // 判斷購物車內(nèi)的item的id,和事件傳遞過來的id,是否相等  
        if (arr[j].goodsId == goodsId) {          
        // 相等的話,給count+1(即再次添加入購物車,數(shù)量+1)  
          arr[j].count = arr[j].count + 1;          
        // 最后,把購物車數(shù)據(jù),存放入緩存(此處不用再給購物車數(shù)組push元素進去,因為這個是購物車有的,直接更新當前數(shù)組即可)  
          try {
            wx.setStorageSync('cart', arr)
          } catch (e) {            
            console.log(e)
          }          
        //關(guān)閉窗口
          wx.showToast({            
            title: '加入購物車成功!',            
            icon: 'success',            
            duration: 2000
          });          
        this.closeDialog();          
            // 返回(在if內(nèi)使用return,跳出循環(huán)節(jié)約運算,節(jié)約性能) 
          return;
        }
      }      
        // 遍歷完購物車后,沒有對應(yīng)的item項,把goodslist的當前項放入購物車數(shù)組  
      arr.push(goods);
    } else {
      arr.push(goods);
    }    
    // 最后,把購物車數(shù)據(jù),存放入緩存  
    try {
      wx.setStorageSync('cart', arr)      
        // 返回(在if內(nèi)使用return,跳出循環(huán)節(jié)約運算,節(jié)約性能) 
      //關(guān)閉窗口
      wx.showToast({        
         title: '加入購物車成功!',        
         icon: 'success',        
         duration: 2000
      });      
        this.closeDialog(); 
      return;
    } catch (e) {      
        console.log(e)
    }
  }

二、購物車頁面讀取緩存獲取商品信息

cart.wxml


         
        
        購物車空空如也  
        

                               去搶購                                                                                                                        {{item.title}}                               ¥{{item.price * item.count}}                                                                                                                                    全選     合計:¥      {{totalMoney}}     去結(jié)算         

cart.wxss

 @import "../template/template.wxss"; 
page{  
  background: #f3f4f5;  
  /* font-size: 37.5px;  */
}  
 .column image {  
     width:33rpx;  
     height:35rpx;  
     display:inline-block;  
     overflow:hidden;  
     float:right;  
     margin-top: -40rpx;  
     margin-left:400rpx;
} 
 .J-shopping-cart-empty{    
     margin: 0;    
     padding: 0;    
     border: 0;    
     font: inherit;    
     font-size: 100%;    
     vertical-align: baseline;
}
.shopping-cart-empty {   
    height: 250px;    
    padding-top: 3.2rem;    
    padding-bottom: 1.6rem;    
    background-color: #fff;    
    text-align: center;    
    position: relative;
} 
.shopping-cart-empty .bg{    
    position: absolute;    
    width: 16.29333rem;    
    height: 6.73333rem;    
    
    background: transparent url();    
    left: 50%;    
    -webkit-transform: translateX(-50%);    
    transform: translateX(-50%);      
    background-size: 100%;    
    top: 0;
} 
.shopping-cart-empty .cart{        
    width: 5.83333rem;    
    height: 7.46rem;    
    background: transparent url() no-repeat;  
    background-size: 100%;    
    margin: 0 auto;
}  
.shopping-cart-empty .button {   
    width: 8.46667rem;    
    height: 1.5rem;    
    display: block;    
    margin: 20rpx auto;
}
.empty-text {    
    font-size: .64667rem;    
    color: #222;    
    margin-top: .53333rem;    
    line-height: .74667rem;    
    font-weight: 400;
}
.button-primary {    
    border: 1px solid #de3c96;    
    color: #de3c96;    
    text-decoration: none;    
    text-align: center;    
    display: block;    
    border-radius: .21267rem;    
    line-height: 1.5rem;    
    -webkit-appearance: none;    
    background: none;    
    padding: 0 .26667rem;    
    margin: 0;    
    white-space: nowrap;    
    position: relative;    
    text-overflow: ellipsis;    
    font-size: .74333rem;    
    font-family: inherit;    
    cursor: pointer;    
    user-select: none;
} 


.cart_container {  
    display: flex;  
    flex-direction: row;  
    background-color: #FFFFFF;  
    margin-bottom: 10rpx;
}
.scroll {   
    margin-bottom: 120rpx; 
}
.column {  
    display: flex;  
    flex-direction: column;
}
.row { 
    display: flex;  
    flex-direction: row;   
    align-items: center;
}
.sku {  
    margin-left: 100rpx;  
    position: absolute;  
    right: 30rpx;  
    margin-top: 30rpx; 
}
.sku-price {  
    color: red;  
    position: relative;   
    margin-top: 30rpx; 
}
.price {  
    color: red;  
    position: relative;
}
.title {  
    font-size: 32rpx;  
    margin-top: 40rpx;
}
.small_text {  
    font-size: 28rpx;  
    margin-right: 40rpx;  
    margin-left: 25rpx;
}
.item-select {  
    width: 40rpx;  
    height: 40rpx;  
    margin-top: 90rpx;  
    margin-left: 20rpx;
}
.item-allselect {  
    width: 40rpx;  
    height: 40rpx; 
    margin-left: 20rpx;   
    margin-top:25rpx;   
}
.item-image {  
    width: 180rpx;  
    height: 180rpx;  
    margin: 20rpx;
} 
.bottom_line {  
    width: 100%;  
    height: 2rpx;  
    background: lightgray;
} 
.bottom_total {  
    position: fixed;  
    display: flex;  
    flex-direction: column;  
    bottom: 0;  
    width: 100%;  
    height: 120rpx;  
    line-height: 120rpx;  
    background: white;  /* margin-top: 300rpx; */
    border-top: 1rpx solid #ccc;  z-index: 99;
}
.button-red {  
    background-color: #f0145a; 
    position: fixed;  
    right: 0;  
    color: white;  
    text-align: center;  
    display: inline-block;  
    font-size: 30rpx;  
    border-radius: 0rpx;  
    width: 30%;  
    height: 120rpx;  
    line-height: 120rpx;  /* border: 1rpx solid #ccc; */
}

cart.js

/**
   * 頁面的初始數(shù)據(jù)
   */
  data: {    
    carts: [], //數(shù)據(jù) 
    iscart: false,    
    hidden: null,    
    isAllSelect: false,    
    totalMoney: 0,
  },
onShow: function () {    
    // 獲取產(chǎn)品展示頁保存的緩存數(shù)據(jù)(購物車的緩存數(shù)組,沒有數(shù)據(jù),則賦予一個空數(shù)組)  
    var arr = wx.getStorageSync('cart') || [];    
    console.info("緩存數(shù)據(jù):"+arr);    // 有數(shù)據(jù)的話,就遍歷數(shù)據(jù),計算總金額 和 總數(shù)量  
    if (arr.length > 0) {      
        // 更新數(shù)據(jù)  
      this.setData({        
        carts: arr,        
        iscart: true,        
        hidden: false
      });      
        console.info("緩存數(shù)據(jù):" + this.data.carts);
    }else{      
        this.setData({        
            iscart: false,        
            hidden: true,
      });
    }
  },

三、購物車商品計算和刪除緩存商品

cart.js

//勾選事件處理函數(shù)  
  switchSelect: function (e) {    
    // 獲取item項的id,和數(shù)組的下標值  
    var Allprice = 0, i = 0;    
    let id = e.target.dataset.id,

      index = parseInt(e.target.dataset.index);    
    this.data.carts[index].isSelect = !this.data.carts[index].isSelect;    //價錢統(tǒng)計
    if (this.data.carts[index].isSelect) {      
        this.data.totalMoney = this.data.totalMoney + (this.data.carts[index].price * this.data.carts[index].count);
    }    else {      
        this.data.totalMoney = this.data.totalMoney - (this.data.carts[index].price * this.data.carts[index].count);
    }    
    //是否全選判斷
    for (i = 0; i < this.data.carts.length; i++) {
      Allprice = Allprice + (this.data.carts[index].price * this.data.carts[index].count);
    }    
    if (Allprice == this.data.totalMoney) {      
        this.data.isAllSelect = true;
    }    else {      
        this.data.isAllSelect = false;
    }    
    this.setData({      
        carts: this.data.carts,      
        totalMoney: this.data.totalMoney,      
        isAllSelect: this.data.isAllSelect,
    })
  },  
    //全選
  allSelect: function (e) {   
     //處理全選邏輯
    let i = 0;    
     if (!this.data.isAllSelect) {      
         this.data.totalMoney = 0;      
         for (i = 0; i < this.data.carts.length; i++) {        
             this.data.carts[i].isSelect = true;        
             this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count);

      }
    }    else {      
        for (i = 0; i < this.data.carts.length; i++) {        
            this.data.carts[i].isSelect = false;
      }      
            this.data.totalMoney = 0;
    }    
            this.setData({      
                carts: this.data.carts,      
                isAllSelect: !this.data.isAllSelect,      
                totalMoney: this.data.totalMoney,
    })
  },  // 去結(jié)算
  toBuy() {
    wx.showToast({      
       title: '去結(jié)算',      
       icon: 'success',      
       duration: 3000
    });    
    this.setData({      
       showDialog: !this.data.showDialog
    });
  },  //數(shù)量變化處理
  handleQuantityChange(e) {    
      var componentId = e.componentId;    
      var quantity = e.quantity;    
      this.data.carts[componentId].count.quantity = quantity;    
      this.setData({      
         carts: this.data.carts,
    });
  },  
   /* 減數(shù) */
  delCount: function (e) {    
   var index = e.target.dataset.index;    
   console.log("剛剛您點擊了加一");    
   var count = this.data.carts[index].count;    // 商品總數(shù)量-1
    if (count > 1) {      
       this.data.carts[index].count--;
    }    
       // 將數(shù)值與狀態(tài)寫回  
    this.setData({      
       carts: this.data.carts
    });    
       console.log("carts:" + this.data.carts);    
       this.priceCount();
  },  
       /* 加數(shù) */
  addCount: function (e) {    
       var index = e.target.dataset.index;    
       console.log("剛剛您點擊了加+");    
       var count = this.data.carts[index].count;    // 商品總數(shù)量+1  
    if (count < 10) {      
       this.data.carts[index].count++;
    }    
       // 將數(shù)值與狀態(tài)寫回  
    this.setData({      
       carts: this.data.carts
    });    
       console.log("carts:" + this.data.carts);    
       this.priceCount();
  }, 
  priceCount: function (e) {    
      this.data.totalMoney = 0;    
      for (var i = 0; i < this.data.carts.length; i++) {      
      if (this.data.carts[i].isSelect == true) {        
          this.data.totalMoney = this.data.totalMoney + (this.data.carts[i].price * this.data.carts[i].count);
      }

    }    
          this.setData({      
              totalMoney: this.data.totalMoney,
        })
  },  
  /* 刪除item */
  delGoods: function (e) {    
      this.data.carts.splice(e.target.id.substring(3),1);    // 更新data數(shù)據(jù)對象  
    if (this.data.carts.length > 0) {      
          this.setData({        
              carts: this.data.carts
      })
      wx.setStorageSync('cart', this.data.carts);      
              this.priceCount();
    } else {      
              this.setData({            
                  cart: this.data.carts,        
                  iscart: false,        
                  hidden: true,
      })
      wx.setStorageSync('cart', []);
    }
  }

關(guān)于“微信小程序商城開發(fā)之怎樣實現(xiàn)商品加入購物車功能”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。


網(wǎng)頁標題:微信小程序商城開發(fā)之怎樣實現(xiàn)商品加入購物車功能
本文路徑:http://fisionsoft.com.cn/article/posecs.html