《仿盒马》app开发技术分享-- 兑换商品取消订单&取消列表展示(77)

简介: 上一节我们实现了兑换订单待发货列表的展示逻辑,成功的在列表中展示出来,我们在订单条目中新增了两个按钮,确认揽收与取消订单,这一节我们要实现的功能是订单的取消,以及订单取消后取消列表的展示

## 技术栈

Appgallery connect

开发准备

上一节我们实现了兑换订单待发货列表的展示逻辑,成功的在列表中展示出来,我们在订单条目中新增了两个按钮,确认揽收与取消订单,这一节我们要实现的功能是订单的取消,以及订单取消后取消列表的展示

功能分析

要实现订单取消的功能,我们需要在条目上点击取消预约按钮时对数据库点击条目的数据进行修改,同时刷新列表数据,把取消后的列表展示到页面上,同时当我们切换tabs页签的时候还要同步刷新组件的内容,保证数据的实时性

代码实现

首先我们实现取消功能,修改订单ordertype状态为1

  Text("取消订单")
                  .fontColor(Color.Black)
                  .fontSize(12)
                  .padding(5)
                  .borderRadius(10)
                  .border({
   width:1,color:Color.Grey})
                  .onClick(async ()=>{
   

                    let order=new points_order_info()
                    order.id=item.id
                    order.user_id=String(this.user!.user_id)
                    order.order_code=item.order_code
                    order.url=item.url
                    order.name=item.name
                    order.order_type=1
                    order.points=item.points
                    if (item.msg!='') {
   
                      order.msg=item.msg
                    }else {
   
                      order.msg="无"
                    }
                    order.amount=1
                    order.nike_name=item.nike_name
                    order.address=item.address
                    order.phone=item.phone
                    order.crete_time=item.crete_time
                    order.cancel_time=this.thisTime()
                    let num = await databaseZone.upsert(order);
                    if (num>0) {
   
                      showToast("兑换取消成功")
                    }
                  })

可以看到我们还需要获取用户id信息,我们从用户首选项里获取一下

 async aboutToAppear(): Promise<void> {
   
      const value = await StorageUtils.getAll('user');
      if (value != "") {
   
      this.user = JSON.parse(value)
    }
  }

然后我们实现tabs切换刷新的方法

  @State currentIndexCheck: number = 0
  @Prop @Watch("onRefresh") currentIndex:number=0

  async onRefresh(){
   

    if (this.user != null) {
   
      let databaseZone = cloudDatabase.zone('default');
      let condition = new cloudDatabase.DatabaseQuery(points_order_info);
      condition.equalTo("user_id", this.user?.user_id).and().equalTo("order_type",0)
      let listData = await databaseZone.query(condition);
      let json = JSON.stringify(listData)
      let data: PointsOrderInfo[] = JSON.parse(json)
      this.orderList=data
    }
  }

  async aboutToAppear(): Promise<void> {
   
      const value = await StorageUtils.getAll('user');
      if (value != "") {
   
      this.user = JSON.parse(value)
        if (this.user != null) {
   
          let databaseZone = cloudDatabase.zone('default');
          let condition = new cloudDatabase.DatabaseQuery(points_order_info);
          condition.equalTo("user_id", this.user?.user_id).and().equalTo("order_type",0)
          let listData = await databaseZone.query(condition);
          let json = JSON.stringify(listData)
          let data: PointsOrderInfo[] = JSON.parse(json)
          this.orderList=data
        }
    }
  }

引用刷新方法

if (num>0) {
   
                      showToast("兑换取消成功")
                      this.onRefresh()
                    }

接下来我们实现取消订单列表的展示,新建取消订单组件


```css
import {
    points_order_info } from '../../../clouddb/points_order_info'
import {
    PointsOrderInfo } from '../../../entity/PointsOrderInfo'
import {
    User } from '../../../entity/User'
import {
    cloudDatabase } from '@kit.CloudFoundationKit';
import showToast from '../../../utils/ToastUtils';
import {
    StorageUtils } from '../../../utils/StorageUtils';
import {
    hilog } from '@kit.PerformanceAnalysisKit';

let databaseZone = cloudDatabase.zone('default');

@Component
export struct  CancelPointsItem{
   
  @State currentIndexCheck: number = 1
  @Prop @Watch("onRefresh") currentIndex:number=0
  @State orderList:PointsOrderInfo[]=[]
  @State user: User|null=null

  async onRefresh(){
   
    if (this.currentIndexCheck==this.currentIndex) {
   
      if (this.user != null) {
   
        let condition = new cloudDatabase.DatabaseQuery(points_order_info);
        condition.equalTo("user_id", this.user?.user_id).and().equalTo("order_type",1)
        let listData = await databaseZone.query(condition);
        let json = JSON.stringify(listData)
        let data: PointsOrderInfo[] = JSON.parse(json)
        this.orderList=data
      }
    }

  }

  async aboutToAppear(): Promise<void> {
   
      const value = await StorageUtils.getAll('user');
      if (value != "") {
   
      this.user = JSON.parse(value)
        if (this.user != null) {
   
          let condition = new cloudDatabase.DatabaseQuery(points_order_info);
          condition.equalTo("user_id", this.user?.user_id).and().equalTo("order_type",1)
          let listData = await databaseZone.query(condition);
          let json = JSON.stringify(listData)
          let data: PointsOrderInfo[] = JSON.parse(json)
          this.orderList=data
        }
    }
  }
  build() {
   
    Column(){
   
      List({
   space:10}){
   
        ForEach(this.orderList,(item:PointsOrderInfo,index:number)=>{
   
          ListItem(){
   
            Column({
   space:10}){
   
              Row(){
   
                Text("订单编号:"+item.order_code)
                  .fontColor(Color.Black)
                  .fontSize(14)

                Text("订单已取消")
                  .fontColor(Color.Black)
                  .fontSize(14)
              }
              .justifyContent(FlexAlign.SpaceBetween)
              .width('100%')

              Row({
   space:10}){
   
                Image($r('app.media.duihuan'))
                  .height(40)
                  .width(40)
                  .borderRadius(5)

                Column({
   space:10}){
   
                  Text("商品类型  积分兑换")
                    .fontColor(Color.Black)
                    .fontSize(14)


                  Text("兑换时间  "+item.crete_time)
                    .fontColor(Color.Black)
                    .fontSize(14)

                  Text("联系方式  "+item.phone)
                    .fontColor(Color.Black)
                    .fontSize(14)

                  Text("取件地址  "+item.address)
                    .fontColor(Color.Black)
                    .fontSize(14)

                }.alignItems(HorizontalAlign.Start)
              }
              .margin({
   top:10})
              .alignItems(VerticalAlign.Top)
              .width('100%')
              .justifyContent(FlexAlign.Start)



            }
            .padding(10)
            .backgroundColor(Color.White)
            .borderRadius(10)
            .width('100%')
            .justifyContent(FlexAlign.SpaceBetween)
            .onClick(()=>{
   
            })
          }
        })
      }
      .padding(10)
    }
  }

  thisTime(): string {
   
    const now = new Date();

    const year = now.getFullYear();
    const month = String(now.getMonth() + 1).padStart(2, '0');
    const day = String(now.getDate()).padStart(2, '0');
    const hours = String(now.getHours()).padStart(2, '0');
    const minutes = String(now.getMinutes()).padStart(2, '0');
    const seconds = String(now.getSeconds()).padStart(2, '0');

    return `${
   year}-${
   month}-${
   day} ${
   hours}:${
   minutes}:${
   seconds}`;
  }

}

到这里我们就实现了订单的取消和取消列表的展示
```

相关文章
|
3月前
|
JSON 监控 数据格式
1688 item_search_app 关键字搜索商品接口深度分析及 Python 实现
1688开放平台item_search_app接口专为移动端优化,支持关键词搜索、多维度筛选与排序,可获取商品详情及供应商信息,适用于货源采集、价格监控与竞品分析,助力采购决策。
|
6月前
《仿盒马》app开发技术分享-- 商品兑换校验(70)
上一节我们实现了可兑换商品的详情,我们能够查看到商品更多的信息,这一节我们来实现商品兑换相关的功能,在进行商品兑换之前,我们在兑换详情页面,点击立即兑换按钮之后我们需要跳转到兑换详情页,但是用户的积分可能达不到我们当前商品的兑换标准,这时候如果我们进入了下个页面,在用户点击确认的时候去校验,就让用户多操作了一步,这样的操作体验非常的不友好,所以我们在兑换前进行校验,通过校验后我们在确认页实现地址添加相关的内容
113 4
|
6月前
|
JSON 数据格式
《仿盒马》app开发技术分享-- 分类右侧商品列表(18)
上一节我们实现了分类页左侧二级分类列表功能,并实现了顶部列表&弹窗跟左侧列表的联动,这一节我们需要在它们联动的基础上继续添加右侧列表的联动效果
104 4
|
6月前
|
存储 数据库
《仿盒马》app开发技术分享-- 商品搜索页(搜索记录&商品搜索)(38)
上一节我们新建了商品搜索页,实现了顶部的搜索bar以及下方的推荐搜索列表,这一节我们要新增一个商品搜索记录列表,以及输入内容之后搜索出对应商品的功能,我们还需要保证搜索内容的唯一性,以及搜索记录的本地数据持久化和搜索记录列表的删除
120 2
|
API 数据库
《仿盒马》app开发技术分享-- 兑换商品订单详情页(80)
我们的兑换商品列表相关的功能都已经实现的差不多了,现在我们还缺少一个订单详情查看的功能,为了ui一致性,我们的订单详情页样式要保持一致性,外观要跟订单、回收单的详情页相似。
125 0
|
6月前
《仿盒马》app开发技术分享-- 兑换商品收货确认&已完成列表展示(79)
上一节我们实现了兑换商品订单的确认揽收功能,实现了tabs切换时的数据刷新,实现了待收货订单的列表展示。这一节我们要实现确认收货功能,并且实现待收货的列表展示功能
122 0
|
6月前
《仿盒马》app开发技术分享-- 兑换商品确认揽收&待收货列表展示(78)
上一节我们实现了订单取消功能,实现了tabs切换时的数据刷新,实现了已取消订单的列表展示。这一节我们要实现揽收功能,并且实现待收货的列表展示功能
154 0
|
JSON 数据库 数据格式
《仿盒马》app开发技术分享-- 兑换页地址商品展示(71)
上一节我们实现了商品兑换的校验功能,这能很好的帮助用户节省更多的时间,同时也能减小服务器的开销,同时我们的业务逻辑也会更加的完善功能也更加的丰富了,这一节我们实现校验通过后的内容,实现地址的选择和兑换商品信息的展示
118 0
|
6月前
《仿盒马》app开发技术分享-- 兑换商品数据插入(67)
上一节我们实现了积分列表的展示,我们可以更直观的查看当前用户积分的收支情况,但是现在我们只有积分收入并没有消费的地方,所以现在我们开始着手积分兑换相关的内容。这一节我们来实现积分兑换商品的内容
99 0
|
6月前
|
数据库
《仿盒马》app开发技术分享-- 商品搜索页(顶部搜索bar&热门搜索)(37)
随着开发功能的逐渐深入,我们的应用逐渐趋于完善,现在我们需要继续在首页给没有使用按钮以及组件添加对应的功能,这一节我们要实现的功能是商品搜索页面,这个页面我们从上到下开始实现功能,首先就是一个搜索的bar,然后是一个系统推荐的热门搜索列表。
121 0

热门文章

最新文章