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

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

技术栈
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)
  }
}

}

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

相关文章
|
8月前
《仿盒马》app开发技术分享-- 确认订单页(数据展示)(29)
上一节我们实现了地址的添加,那么有了地址之后我们接下来的重点就可以放到订单生成上了,我们在购物车页面,点击结算会跳转到一个 订单确认页面,在这个页面我们需要有地址选择、加购列表展示、价格计算、优惠计算、商品数量展示等信息。
219 3
|
8月前
|
存储 缓存 前端开发
《仿盒马》app开发技术分享-- 用户登录页(业务逻辑)(21)
上一节我们实现了静态的用户登录页,这一节我们需要给他添加上业务逻辑,实现跟云数据库的互通,同时跟整个应用关联起来,因为我们还没有实现用户的注册页面,所以这里我们在云数据库的用户数据插入暂时先不做同用户名的校验,我们在云端先插入几条数据,暂时专注于查询即可
197 5
|
8月前
|
定位技术
《仿盒马》app开发技术分享-- 地图选点(27)
上一节我们实现了地图的简单展示,这一节我们要实现的内容是,根据展示的地图,实现当前定位功能,当前位置的poi地址功能,以及列表的展示,给地图添加标记,展示自己的当前定位
150 4
|
8月前
|
定位技术 API
《仿盒马》app开发技术分享-- 原生地图展示(26)
上一节我们实现了获取当前用户的位置,并且成功的拿到了经纬度,这一节我们就要根据拿到的经纬度,结合我们其他的知识点来实现地图的展示。
191 4
|
8月前
《仿盒马》app开发技术分享-- 个人中心页面(19)
上一节我们实现了分类页面的所有联动效果,这一节我们要开始完成一个新的页面,这个页面是我们主界面的第四个板块,就是个人中心页面。在这个模块,我们可以显示一些用户信息,以及用户相关的各类功能的入口
137 4
|
8月前
|
JSON 数据格式
《仿盒马》app开发技术分享-- 分类右侧商品列表(18)
上一节我们实现了分类页左侧二级分类列表功能,并实现了顶部列表&弹窗跟左侧列表的联动,这一节我们需要在它们联动的基础上继续添加右侧列表的联动效果
122 4
|
8月前
|
JSON 数据挖掘 数据格式
《仿盒马》app开发技术分享-- 分类左侧列表(17)
上一节我们实现了分类页面的顶部导航栏全选弹窗列表,并实现了跟顶部列表的点击选中联动效果,这一节我们要实现的功能是,分类模块的左侧列表,它同样也需要跟弹窗列表的点击,顶部列表的点击有联动的效果
135 4
|
8月前
|
数据库
《仿盒马》app开发技术分享-- 确认订单页(业务逻辑)(30)
上一节我们实现了确认订单页的页面绘制和价格计算优惠计算,订单列表展示等功能,这一节我们来实现确认订单页的整个业务逻辑。首先我们要实现的就是地址的选择,然后把我们计算的价格,商品列表等数据保存起来,然后我们开始创建订单表实体类等,把这些数据提交到订单表中
222 3
|
8月前
|
存储 定位技术 数据库
《仿盒马》app开发技术分享-- 新增地址(28)
上一节我们实现了地图选点,获取当前位置,在地图上添加标记,根据当前的定位获取poi地址列表等功能,这些全部都为了我们这一节而铺垫,这一节我们要实现的是新增地址,把我们的用户信息,填写收件人、门牌号、手机号、经纬度、详细地址等信息添加到我们的云数据库中,然后在地址查询列表里展示出来。
188 2
|
8月前
|
前端开发
《仿盒马》app开发技术分享-- 个人中心页or静态头像选择(业务逻辑)(22)
上一节我们实现了登录页面的业务逻辑,并且成功的实现了数据的查询,同时我们新增了用户首选项的工具类,现在主界面往登录页面跳转,登录成功后我们关闭登录页面,这时候我们就会回到个人中心页面,那么现在我们的业务逻辑是一种什么样的形式?登录成功后我们需要显示用户的信息,并且在下次登录时依旧展示个人信息。同时我们还新增了一个头像选择的静态弹窗,丰富个人信息页面
194 1