微信小程序购物车-多商家-多商品

主要看一下购物车的计算过程 实现后的基本样式

具体代码

主要看shops页面, 前提:获取基本的数据,由于数据太长,还请下载项目后查看,github地址:https://github.com/cxy-js/wechat-shop

  • shops页面data数据
 data: {
    shops: {},           //商品
    curt: 0,             //分类id
    curindex: 0,         //当前index
    idx: 0,
    ishow: 1,
    cai: [],             //菜的数组
    allprice: 0,        //总家
    allnum: 0          //总商品数
  },
 onLoad: function (options) {
    let id = options.id;
    //商家详情本地请求资源
    wx.showToast({
      title: '成功',
      duration: 500,
      success: (e) => {
        if (e.errMsg === 'showToast:ok') {
          this.setData({
            shops: data.shops[id],
            cai: data.shops[id].cai
          })
          console.log(this.data.cai)
        } else {
          console.log(e.errMsg)
        }
      }
    })
  }
  • id 为index页面传过来的商家 id;依据商家id来显示不同商家
  • 进入商家页面 后的布局;头部就不看了,主要看菜的分类以及都有哪些菜 在这之前需要在商品以及评价的切换中拿到curt,curt就是分类的id
  • 菜品切换
        <view class='left-nav'>
          <view wx:for="{{shops.lefttitle}}">
            <view class="shops-left-title {{curt == item.id ? 'bg' : ''}}" catchtap="goIndex" data-id="{{item.id}}" data-index="{{index}}">
              <text class='t'>{{item.lefttitle}}</text>
            </view>
          </view>
        </view>
  • 切换代码就不看了,主要是拿到分类的id=>curt下面就是分类下的布局
<scroll-view scroll-y class='scroll'>
          <view class='cai'>
            <!--一句curt来显示不是菜 curt===分类id-->
            <view wx:for="{{cai[curt]}}" wx:for-item="cai" wx:for-index="caiindex">
              <!--具体的菜-->
              <view class='right-cai'>
                <image src="{{cai.img}}"></image>
                <view class='middle'>
                  <text>{{cai.cainame}}</text>
                  <text class='shou'>月售{{cai.shou}}</text>
                  <text class='price'>¥{{cai.price}}</text>
                </view>
                <!--加减按钮-->
                <view class='btn'>
                  <text class='add' catchtap="minus" data-index="{{caiindex}}" wx:if="{{cai.num===0?false:true}}">-</text>
                  <text class='cainum' wx:if="{{cai.num===0?false:true}}">{{cai.num}}</text>
                  <text class='add' catchtap="add" data-index="{{caiindex}}">+</text>
                </view>
              </view>
            </view>
          </view>
 </scroll-view>

先来看下增加的计算逻辑

 //增加商品数量
  add(e) {
    let index = e.currentTarget.dataset.index
    let cai = this.data.cai;
    let curt = this.data.curt;//当前是哪个分类下的菜
    let num = cai[curt][index].num;//当前菜的数量
    num++;
    cai[curt][index].num = num //点击后菜的数量
    this.setData({
      cai: cai   //更新菜
    })
    this.getAll() //计算总计
  }

点击按钮时依据哪个分类下的哪个菜来区分;每点击一次商品数量+1;最后需要实时计算价格 this.getAll()

减少的计算逻辑与增加超不多

 minus(e) {
    let index = e.currentTarget.dataset.index
    let cai = this.data.cai;
    let curt = this.data.curt;//当前是哪个分类下的菜
    let num = cai[curt][index].num;
    if (num <= 0) {
      return false;
    }
    num--;
    //重新赋值数量
    cai[curt][index].num = num
    this.setData({
      cai: cai
    })
    this.getAll()
  }

多了一个判断而已

接下来就是计算总价格

  //计算总价
  getAll() {
    let cai = this.data.cai;
    let total = 0;
    let allnum = 0;
    let allcainame=""
    //循环当前类别菜数组
    for (let i = 0; i < cai.length; i++) {
      let c = cai[i];
      for (let j = 0; j < c.length; j++) {
        let num = c[j].num
        let price = c[j].price;
        //计算总商品数        
        allnum += num
         //计算总价
        total += num * price
      }
    }
    this.setData({
      allprice: total,
      allnum: allnum
    });
  },

里面都有注释也不难看懂,就不解释了!!!

注意一切已数据为中心!!

最后点击去结算的跳转

 //跳转支付页面
  getAllprice() {
    // console.log(this.data.shops)
    //传递菜馆名,总价
    let title = this.data.shops.title;
    let allprice = this.data.allprice;
    let cainame = this.data.cainame;
    if (this.data.allnum === 0) {
      wx.showModal({
        title: '商品为空!',
        content: '您选择商品了吗?',
      })
      return
    } else {
      //商品数量不能为0
      this.getAll()
      wx.navigateTo({
        url: '../pay/pay?allprice=' + allprice + '&title=' + title 
      })
    }
  }

判断一下是否有商品 在这里传递的数据都可以带入到支付页面

结束需要代码请移步到我的github

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏向治洪

ARKit 简介

ARKit 简介 苹果在AR一直布局VR,最近的苹果开发者大会上,果家终于放出大招:iOS移动端ARKit平台以及VR兼容新桌面操作系统macOS High S...

28460
来自专栏吉浦迅科技

让NVIDIA Jetson AGX Xavier火力全开的秘密

之前我们写过让Jetson TX2火力全开的秘密,让大家知道命令行工具nvpmodel能够定义一组参数,从而有效地定义给定功率的性能。

3.7K30
来自专栏PPV课数据科学社区

【课程推荐】数据可视化神器-tableau入门

数据可视化——Tableau Tableau Desktop 是基于斯坦福大学突破性技术的软件应用程序。Tableau 是桌面系统中最简单的商业智能工...

36430
来自专栏Coding迪斯尼

VUE+WebPack精美游戏设计:实现微信红包铜钱转动特性和页面数据的本地存储

22940
来自专栏自学笔记

Unity基本操作以及Roll A Ball窗口界面以及菜单Roll A Ball

第一个手部图标,可以拖动物体,对准物体点击就可以拖动。第二个就是指针图标,可以选择物体的移动方向。可以选择x,y,z三个方向进行移动。第三个就是旋转图标,可以...

19020
来自专栏数据小魔方

创意彩虹图表!

今天跟大家分享一款当前非常流行的创意彩虹图表! ▽ 这种图表其实制作起来没有任何难度,主要是使用特殊的数据展现形式以及协调匀称的配色,使得整个图表看起来非常的新...

29490
来自专栏SEO

「技巧」如何在图片搜索中排名更高

355110
来自专栏大数据文摘

交互式数据可视化,在Python中用Bokeh实现

431110
来自专栏区块链源码分析

用零知识证明解决投票安全

我们经常会遇到需要给别人投票的情况,比如有些公司会组织员工给领导做反向打分,但是往往员工都不敢“真心实意”的打分,为什么呢?归根结底是害怕所谓的匿名不是真匿名...

468180
来自专栏MelonTeam专栏

UI走查与显示器色彩偏差

UI提了一个UI走查问题,说一个按钮的底色不对。 ? 标明色值为0xff3b30。 我一看代码,看见 ? 没有问题啊,然后在模拟器上取色值,发现,还真的不对,屏...

243100

扫码关注云+社区

领取腾讯云代金券