《仿盒马》app开发技术分享-- 加入购物车&加购列表展示(12)

鸿蒙小林
• 阅读 3

技术栈 Appgallery connect

开发准备

上一节我们实现了商品详情页面的规格选择弹窗,这在任何购物类应用中都是最常用的功能之一。当然了,作为一个购物类的应用,我们仅仅展示是用处不大的,我们还需要有添加的动作。这一节我们就来实现添加到购车里并且在购物车内简单展示的功能。

功能分析 1.加入购物车 我们已经实现了弹窗,加入购物车就需要在切换规格的同时,点击提交对应的数据,这里要注意,我们针对同一个数据,是不需要创建多条的,仅仅需要修改加购的商品数量即可,所以这里我们还需要先查在加,防止同一条数据分开生成多条 2.加购列表展示 这里就是针对我们已经添加的数据进行一个简单的列表展示,只需要查询出来展示即可

代码实现 首先在点击事件中我们实现先查后加的逻辑,根据当前选中的规格下标id和商品id作为条件去查询,根据返回数据的条目来进行针对性的处理

let databaseZone = cloudDatabase.zone('default'); let condition = new cloudDatabase.DatabaseQuery(cart_product_list); condition.equalTo("productId",this.product?.id).and().equalTo("productSpecId",this.specList[this.checkIndex].id) let listData = await databaseZone.query(condition); let json = JSON.stringify(listData) hilog.info(0x0000, 'testTag', Succeeded in upserting data, result: ${json}); let request:CartProductList[]=JSON.parse(json) let cartPush = new cart_product_list();

        if (request.length>0) {
          let data:CartProductList=request[0]
          cartPush.id=data.id;
          cartPush.productId=data.productId//商品id
          cartPush.productSpecId=data.productSpecId//规格id
          cartPush.productName=data.productName//商品名称
          cartPush.productSpecName=data.productSpecName
          cartPush.productImgAddress=data.productImgAddress
          cartPush.buyAmount=this.addNumber+data.buyAmount//商品数量
          cartPush.isNeedPay=data.isNeedPay//是否选中 默认为true
          cartPush.activityType=data.activityType//活动类型 暂无
          cartPush.productPrice=data.productPrice//价格
          cartPush.productOriginalPrice=data.productOriginalPrice//划线价
          cartPush.couponPrice=data.couponPrice
        }else {

          cartPush.id=Math.floor(Math.random() * 1000000);
          cartPush.productId=this.product!.id//商品id
          cartPush.productSpecId=this.specList[this.checkIndex].id//规格id
          cartPush.productName=this.product!.name//商品名称
          cartPush.productSpecName=this.specList[this.checkIndex].name
          cartPush.productImgAddress=this.product!.url//图片地址
          cartPush.buyAmount=this.addNumber//商品数量
          cartPush.isNeedPay=true//是否选中 默认为true
          cartPush.activityType="1"//活动类型 暂无
          cartPush.productPrice=this.product!.price//价格
          cartPush.productOriginalPrice=this.product!.original_price//划线价
          cartPush.couponPrice=0
        }



        let num = await databaseZone.upsert(cartPush);
        hilog.info(0x0000, 'testTag', `Succeeded in upserting data, result: ${num}`);
        if (num>0) {
          showToast("修改成功"+num+"条")
        }
      }catch (err) {
        hilog.info(0x0000, 'testTag', `Succeeded in upserting data, result: ${err}`);

      }

这样我们就可以有效的区分数据了。我们进行添加,数据已经成功插入

接下来我们实现加购列表,首先进行页面的创建,在生命周期函数里进行数据的查询

import { CartProductList } from "../entity/CartProductList" import { cloudDatabase } from "@kit.CloudFoundationKit"; import { cart_product_list } from "../clouddb/cart_product_list"; import { hilog } from "@kit.PerformanceAnalysisKit"; let databaseZone = cloudDatabase.zone('default');

@Preview @Component export struct CartList {

@State productList:CartProductList[]=[]

@State flag:boolean=false

async aboutToAppear(): Promise {

let condition = new cloudDatabase.DatabaseQuery(cart_product_list);
let listData = await databaseZone.query(condition);
let json = JSON.stringify(listData)
this.productList= JSON.parse(json)
hilog.info(0x0000, 'testTag', `Succeeded in upserting data, result: ${listData}`);

this.flag=true

} build() { Column(){ if (this.flag){ List(){ ForEach(this.productList,(item:CartProductList,index:number)=>{ ListItem(){ Row(){ Image(item.productImgAddress) .height(120) .width(120) Column(){ Text(item.productName) .fontColor(Color.Black) .fontSize(16)

               Text(item.productSpecName)
                 .fontColor(Color.Grey)
                 .fontSize(14)

               Text(){
                 Span("¥ ")
                   .fontSize(14)
                   .fontColor(Color.Red)
                 Span(item.productPrice+"")
                   .fontSize(22)
                   .fontColor(Color.Red)
               }

               Text("¥"+item.productOriginalPrice+"")
                 .fontColor('#999')
                 .decoration({
                   type: TextDecorationType.LineThrough,
                   color: Color.Gray
                 })
                 .fontSize(16)
                 .margin({left:10})
             }

             Text("已经加购数量"+item.buyAmount)
               .fontColor(Color.Black)
         }
        }
      })

    }.height('auto')
    .layoutWeight(1)
  }
}

}

} 到这里我们的功能就实现了, 下一节我们将要针对购物车进行详细的教学

点赞
收藏
评论区
推荐文章
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 首页商品流(7)
技术栈Appgalleryconnect开发准备上一节我们实现了首页banner模块的功能,现在我们的首页还需要添加商品列表,作为一个购物类应用,商品列表是非常重要的一个模块,所以我们尽量把它设计的足够完善,参数能更好的支持我们后期复杂的逻辑,它需要有图片
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 商品详情页(10)
技术栈Appgalleryconnect开发准备上一节我们实现了自定义标题栏和商品详情的数据接收,我们已经拿到了想要的数据,这一节我们要丰富商品详情页的内容。商品详情页面我们需要展示的是商品的各个属性参数、商品的图片、商品规格、活动详情等功能分析商品详情页
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 商品规格弹窗(11)
技术栈Appgalleryconnect开发准备上一节我们实现了商品详情页面,并且成功在页面上展示了商品的图片、商品规格、活动详情等信息,要知道同一种商品大多数都是有多种型号跟规格的,所以这一节我们来实现商品的规格弹窗。这节的要点是自定义弹窗的运用。功能分
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 购物车基础功能实现(13)
技术栈Appgalleryconnect开发准备上一节我们实现了加入购物车和购物车列表的简单展示。对一个电商类的应用来说,这很显然是不够的,我们的购物车内容应该更加的丰富,他需要用户能自主的去选择想要结算的商品,删除一些不需要的商品,或者取消掉一些本次不结
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 购物车功能完善(14)
技术栈Appgalleryconnect开发准备上一节我们实现了购物车商品列表的状态切换,已添加商品数量的增减,已添加商品滑动删除,已添加商品在选中情况下的价格计算。这一节我们在这些功能的基础上实现云端记录,因为我们现在只有数据的查询是从云端获取的,其他的
鸿蒙小林 鸿蒙小林
9小时前
《仿盒马》app开发技术分享-- 分类模块顶部导航列表(15)
技术栈Appgalleryconnect开发准备上一节我们实现了购物车商品列表的大部分功能,实现了商品的添加、删除、增减、价格计算等业务,并且都跟云端进行通信。现在我们继续对项目进行改造,这一节我们要改造的内容是分类页,这个页面我们在之前的非端云一体化项目
鸿蒙小林 鸿蒙小林
2小时前
《仿盒马》app开发技术分享-- 分类右侧商品列表(18)
技术栈Appgalleryconnect开发准备上一节我们实现了分类页左侧二级分类列表功能,并实现了顶部列表&弹窗跟左侧列表的联动,这一节我们需要在它们联动的基础上继续添加右侧列表的联动效果功能分析1.列表展示当我们选择顶部一级分类列表时,左侧列表展示二级
鸿蒙小林 鸿蒙小林
2小时前
《仿盒马》app开发技术分享-- 确认订单页(数据展示)(29)
技术栈Appgalleryconnect开发准备上一节我们实现了地址的添加,那么有了地址之后我们接下来的重点就可以放到订单生成上了,我们在购物车页面,点击结算会跳转到一个订单确认页面,在这个页面我们需要有地址选择、加购列表展示、价格计算、优惠计算、商品数量
鸿蒙小林 鸿蒙小林
2小时前
《仿盒马》app开发技术分享-- 购物车业务逻辑完善(34)
技术栈Appgalleryconnect开发准备之前我们已经实现了购物车相关的内容,实现了购物车数据列表的展示,但是我们结算订单之后我们的购物车列表并没有刷新,而且底部的状态栏并没有明显的数据展示来提醒用户,而且当我们在商品详情页添加新商品,底部也没有同步
鸿蒙小林 鸿蒙小林
2小时前
《仿盒马》app开发技术分享-- 回收订单详情页(46)
技术栈Appgalleryconnect开发准备上一节我们实现了订单列表的所有功能,展示了待取件、已取消、运输中、已完成等订单列表的数据展示,并且在对应的订单中点击功能按钮实现了订单的状态切换,这一节我们就要通过点击对应列表内的订单进入相应的订单详情页,展