0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學(xué)習在線(xiàn)課程
  • 觀(guān)看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區
會(huì )員中心
創(chuàng )作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內不再提示

HarmonyOS開(kāi)發(fā)實(shí)例:【菜單app】

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-14 11:40 ? 次閱讀

簡(jiǎn)介

分布式菜單demo 模擬的是多人聚餐點(diǎn)菜的場(chǎng)景,不需要掃碼關(guān)注公眾號等一系列操作,通過(guò)分布式數據庫可以方便每個(gè)人可及時(shí)查看到訂單詳情,數量,總額等;效果如下

  • demo效果
    show

工程目錄

完整的項目結構目錄如下

├─entry
│  └─src
│      └─main
│          │  config.json  // 應用配置文件
│          │  
│          ├─ets
│          │  └─MainAbility
│          │      │  app.ets  // 應用程序主入口
│          │      │  
│          │      ├─model
│          │      │      CommonLog.ets  // 日志類(lèi)
│          │      │      MenuData.ets  // 初始化菜單數據類(lèi)
│          │      │      MenuListDistributedData.ets  // 加入菜單分布式數據庫
│          │      │      RemoteDeviceManager.ets  // 分布式拉起設備管理類(lèi)
│          │      │      SubmitData.ets   // 結算訂單分布式數據庫
│          │      │      
│          │      └─pages
│          │              detailedPage.ets // 菜品詳細頁(yè)面
│          │              index.ets // 首頁(yè)
│          │              menuAccount.ets // 訂單詳情頁(yè)面
│          │              
│          └─resources
│              ├─base
│              │  ├─element
│              │  │      string.json
│              │  │      
│              │  ├─graphic
│              │  ├─layout
│              │  ├─media   // 存放媒體資源
│              │  │      icon.png
│              │  │      icon_add.png
│              │  │      icon_back.png
│              │  │      icon_cart.png
│              │  │      
│              │  └─profile
│              └─rawfile

鴻蒙開(kāi)發(fā)文檔[qr23.cn/AKFP8k]

開(kāi)發(fā)步驟

搜狗高速瀏覽器截圖20240326151450.png

1. 新建OpenHarmony ETS項目

鴻蒙next星河版紫料mau123789是v拿取

在DevEco Studio中點(diǎn)擊File -> New Project ->Empty Ability->Next,Language 選擇ETS語(yǔ)言,最后點(diǎn)擊Finish即創(chuàng )建成功。 image-20211124092813545

image-20211124092813545

2. 編寫(xiě)商品展示主頁(yè)面

image-20211124093106260

2.1用戶(hù)信息

1): 主要用到[Flex]容器[Image]和[Text]組件;

2): 用戶(hù)名稱(chēng)和頭像圖標,根據設備序列號不同,可展示不同的名稱(chēng)和圖標;

3): 點(diǎn)擊右上角分享的小圖標,可分布式拉起局域網(wǎng)內的另一臺設備;

@Component
struct MemberInfo {
  @Consume userImg: Resource
  @Consume userName: string
  
  aboutToAppear() {
  // 根據設備序列號不同,展示不同的名稱(chēng)和圖標
    CommonLog.info('==serial===' + deviceInfo.serial);
    if (deviceInfo.serial == '150100384754463452061bba4c3d670b') {
      this.userImg = $r("app.media.icon_user")
      this.userName = 'Sunny'
    }
    else {
      this.userImg = $r("app.media.icon_user_another")
      this.userName = 'Jenny'
    }
  }

  build() {
    Flex({ direction: FlexDirection.Column }) {
      Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
        Image(this.userImg)
          .width('96lpx')
          .height('96lpx')
          .margin({ right: '18lpx' })
        Text(this.userName)
          .fontSize('36lpx')
          .fontWeight(FontWeight.Bold)
          .flexGrow(1)
        Image($r("app.media.icon_share"))
          .width('64lpx')
          .height('64lpx')
      }
      // 打開(kāi)分布式設備列表
      .onClick(() = > {
        this.DeviceDialog.open()
      })
      .layoutWeight(1)
      .padding({ left: '48lpx', right: '48lpx' })

      Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
        Column() {
          Text('124')
            .fontSize('40lpx')
            .margin({ bottom: '24lpx' })
          Text('積分')
            .fontSize('22lpx')
            .opacity(0.4)
        }
        .flexGrow(1)

        Column() {
          Text('0')
            .fontSize('40lpx')
            .margin({ bottom: '24lpx' })
          Text('優(yōu)惠劵')
            .fontSize('22lpx')
            .opacity(0.4)
        }
        .flexGrow(1)

        Column() {
          Image($r("app.media.icon_member"))
            .width('48lpx')
            .height('48lpx')
            .margin({ bottom: '24lpx' })
          Text('會(huì )員碼')
            .fontSize('22lpx')
            .fontColor('#000000')
            .opacity(0.4)
        }
        .flexGrow(1)
      }
      .layoutWeight(1)
    }
    .width('93%')
    .height('25%')
    .borderRadius('16lpx')
    .backgroundColor('#FFFFFF')
    .margin({ top: '24lpx', bottom: '32lpx' })
  }
}
2.2列表展示

1): 主要用到[Flex]容器 和[Scroll]容器[Image]和[Text]組件;

2): 從首頁(yè)點(diǎn)擊列表進(jìn)入菜品詳細頁(yè)面,點(diǎn)菜成功后會(huì )自動(dòng)返回首頁(yè),此時(shí)列表需要動(dòng)態(tài)更新菜品的數量;

@Component
struct MenuHome {
  private specialty: any[]
  private winterNew: any[]
  private classic: any[]
  private soup: any[]
  private menuItems: MenuData[]
  private titleList = ['招牌菜', '冬季新品', '下飯菜', '湯品']
  @State name: string = '招牌菜'

  build() {
    Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Start }) {
      Flex({ direction: FlexDirection.Column, justifyContent: FlexAlign.SpaceAround }) {
        ForEach(this.titleList, item = > {
          Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.Start }) {
            Text(item)
              .fontSize('24lpx')
          }
          .padding({ left: '24lpx' })
          .backgroundColor(this.name == item ? '#1A006A3A' : '#FFFFFF')
          .height('160lpx')
          .onClick(() = > {
            this.name = item
            if (this.name == '招牌菜') {
              this.menuItems = initializeOnStartup(this.specialty);
            }
            else if (this.name == '冬季新品') {
              this.menuItems = initializeOnStartup(this.winterNew);
            }
            else if (this.name == '下飯菜') {
              this.menuItems = initializeOnStartup(this.classic);
            }
            else if (this.name == '湯品') {
              this.menuItems = initializeOnStartup(this.soup);
            }
          })
        }, item = > item)
      }
      .width('20%')
      .backgroundColor('#FFFFFF')

      Flex({ direction: FlexDirection.Column }) {
        Text(this.name)
          .fontSize('32lpx')
          .fontWeight(FontWeight.Bold)
          .opacity(0.4)
          .height('8%')
        Scroll() {
          Column() {
            List() {
              ForEach(this.menuItems, item = > {
                ListItem() {
                  MenuListItem({ menuItem: item })
                }
              }, item = > item.id.toString())
            }
          }
        }
        .height('92%')
      }
      .margin({ left: '10lpx' })
      .width('75%')

    }
    .height('50%')
  }
}
2.3底部總額

1): 主要用到[Flex]容器 和[Stack]容器[Image]和[Text]組件;

2): 從首頁(yè)點(diǎn)擊列表進(jìn)入菜品詳細頁(yè)面,點(diǎn)菜成功后會(huì )自動(dòng)返回首頁(yè),更新訂單數量和總額;

3): 點(diǎn)擊底部總額框,將訂單列表加入分布式數據庫,@entry模擬監聽(tīng)數據庫變化,拉起訂單列表詳情頁(yè)面;

@Component
struct TotalInfo {
  @Consume TotalMenu: any[];
  private total: number = 0;
  private amount: number = 0;
  private remoteData: MenuListData

  aboutToAppear() {
    for (var index = 0; index < this.TotalMenu.length; index++) {
      this.total = this.total + this.TotalMenu[index].price * this.TotalMenu[index].quantity
      this.amount = this.amount + this.TotalMenu[index].quantity
    }
  }

  build() {
    Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
      Stack({ alignContent: Alignment.Center }) {
        Image($r("app.media.icon_cart"))
          .width('96lpx')
          .height('96lpx')
          .margin({ left: '22lpx' })
        Text(this.amount.toString())
          .backgroundColor('#F84747')
          .borderRadius('30plx')
          .fontSize('24plx')
          .textAlign(TextAlign.Center)
          .fontColor('#FFFFFF')
          .width('50lpx')
          .height('50lpx')
          .margin({ left: '100lpx', bottom: '85lpx' })
      }
      .width('150lpx')
      .height('150lpx')

      Text('¥')
        .fontSize('22lpx')
        .fontColor('#006A3A')
        .margin({ left: '22lpx' })
      Text(this.total.toString())
        .fontSize('40lpx')
        .fontColor('#006A3A')
        .flexGrow(1)
      Text('點(diǎn)好了')
        .height('100%')
        .width('35%')
        .fontColor('#FFFFFF')
        .backgroundColor('#F84747')
        .textAlign(TextAlign.Center)
    }
    // 將總的訂單數據,加入分布式數據庫
    .onClick(() = > {
      this.remoteData.putData("menu_list", this.TotalMenu)
    })
    .width('100%')
    .height('10%')
    .backgroundColor('#FFFFFF')
  }
}

3. 編寫(xiě)菜單詳細頁(yè)面

image-20211124093106260

3.1 菜單詳情

1): 主要用到[Flex]容器 [Image]和[Text]組件[Button]組件;

2): 辣度可以選擇;

3):點(diǎn)擊選好了,需要判斷該菜品是否已經(jīng)在總訂單里面,并判斷是哪一個(gè)用戶(hù)添加,根據判斷,做出相應的增加;

@Component
struct detailInfo {
  private menuItem
  private spicyList = ['正常辣', '加辣', '少辣']
  @State spicy: string = '正常辣'
  private TotalMenu: any[]
  private index = 0
  private userName: string

  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center }) {
      Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Start, justifyContent: FlexAlign.Start }) {
        Flex({ direction: FlexDirection.Row }) {
          Flex() {
            Image(this.menuItem.imgSrc)
              .objectFit(ImageFit.Contain)
          }

          Flex({ direction: FlexDirection.Column }) {
            Text(this.menuItem.name)
              .fontSize('32lpx')
              .flexGrow(1)
            Text(this.menuItem.remarks)
              .fontSize('22lpx')
              .fontColor('#000000')
              .opacity(0.6)
              .flexGrow(1)
            Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
              Text('¥')
                .fontSize('22lpx')
              Text(this.menuItem.price.toString())
                .fontSize('40lpx')
              Text('/份')
                .fontSize('22lpx')
                .flexGrow(1)
              Image($r("app.media.icon_reduce"))
                .width('44lpx')
                .height('44lpx')
                .onClick(() = > {
                  prompt.showToast({
                    message: "Reduce function  to be completed",
                    duration: 5000
                  })
                })
              Text(this.menuItem.quantity.toString())
                .margin({ left: '15lpx', right: '15lpx' })
              Image($r("app.media.icon_add"))
                .width('44lpx')
                .height('44lpx')
                .margin({ right: '15lpx' })
                .onClick(() = > {
                  prompt.showToast({
                    message: "Increase function to be completed",
                    duration: 5000
                  })
                })
            }
            .flexGrow(2)
          }
        }
        .height('40%')
        .margin({ top: '40lpx', bottom: '24lpx' })

        Button()
          .backgroundColor('#000000')
          .opacity(0.1)
          .height('2lpx')
          .margin({ left: '24lpx' })
          .width('92%')

        Flex({ direction: FlexDirection.Row }) {
          Button()
            .backgroundColor('#006A3A ')
            .width('8lpx')
            .height('48lpx')
            .margin({ right: '12lpx' })
          Text('辣度')
        }
        .margin({ left: '44lpx', top: '48lpx', bottom: '32lpx' })

        Flex({ direction: FlexDirection.Row, justifyContent: FlexAlign.SpaceEvenly }) {
          ForEach(this.spicyList, item = > {

            Button(item)
              .fontSize('28lpx')
              .height('60lpx')
              .width('156lpx')
              .borderRadius('12lpx')
              .backgroundColor(this.spicy == item ? '#006A3A' : '#0D000000')
              .fontColor(this.spicy == item ? '#FFFFFF' : '#000000')

              .onClick(() = > {
                this.spicy = item
              })
          }, item = > item)
        }
      }
      .margin({ top: '56lpx' })
      .width('92%')
      .height('50%')
      .borderRadius('16lpx')
      .backgroundColor('#FFFFFF')


      Button('選好了')
        .fontSize('36lpx')
        .width('80%')
        .height('7%')
        .backgroundColor('#F84747')
        .onClick(() = > {
          for (this.index = 0; this.index < this.TotalMenu.length; this.index++) {
            if (this.TotalMenu[this.index].name == this.menuItem.name && this.TotalMenu[this.index].spicy == this.spicy) {
              this.TotalMenu[this.index].quantity = this.TotalMenu[this.index].quantity + 1;
              if (this.userName == 'Sunny') {
                this.TotalMenu[this.index].userNumber = this.TotalMenu[this.index].userNumber + 1;
              } else if (this.userName == 'Jenny') {
                this.TotalMenu[this.index].anotherUserNumber = this.TotalMenu[this.index].anotherUserNumber + 1;
              }
              break;
            }
          }
          // 菜名不一樣,辣度不一樣,都需要重新push到列表里面
          if (this.index == this.TotalMenu.length) {
            this.menuItem.spicy = this.spicy;
            this.menuItem.quantity = 1;
            //根據不用的用戶(hù)名稱(chēng),
            if (this.userName == 'Sunny') {
              this.menuItem.userNumber = 1;
            } else if (this.userName == 'Jenny') {
              this.menuItem.anotherUserNumber = 1;
            }
            this.TotalMenu.push(this.menuItem);
          }
          router.push({
            uri: 'pages/index',
            params: { menuItem: this.menuItem, TotalMenu: this.TotalMenu }
          })
        })
        .margin({ top: '10%' })
    }
  }
}

4. 編寫(xiě)訂單詳情頁(yè)面

image-20211124093106260

4.1 訂單列表

1): 主要用到[Flex]容器[Image]和[Text]組件[Button]組件;

2): 點(diǎn)擊下單,將"submitOk" 加入分布式數據庫,監聽(tīng)數據庫變化后,彈出自定義對話(huà)框;

@Component
struct TotalItem {
  private totalMenu: MenuData

  build() {
    Flex({ direction: FlexDirection.Column }) {
      Flex({ direction: FlexDirection.Row, alignContent: FlexAlign.Start, justifyContent: FlexAlign.Start }) {

        Image(this.totalMenu.imgSrc)
          .width('210lpx')
          .height('100%')
        Flex({ direction: FlexDirection.Column }) {
          Text(this.totalMenu.name)
            .fontSize('32lpx')
            .flexGrow(1)
          Text(this.totalMenu.spicy)
            .fontSize('22lpx')
            .fontColor('#000000')
            .opacity(0.6)
            .flexGrow(1)
          Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
            Text('¥')
              .fontSize('22lpx')
            Text(this.totalMenu.price.toString())
              .fontSize('40lpx')
            Text('/份')
              .fontSize('22lpx')
              .flexGrow(1)
            Text(this.totalMenu.quantity.toString())
              .fontColor("#F84747")
              .fontSize('40lpx')
          }
          .flexGrow(2)
        }
        .padding({ left: '5%', top: '6%' })
        .width('70%')
      }
      .height('180lpx')

      Button()
        .backgroundColor('#000000')
        .opacity(0.1)
        .height('2lpx')
        .margin({ top: '20lpx' })
        .width('100%')


      if (this.totalMenu.userNumber > 0) {
        Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
          Image(this.totalMenu.userImg)
            .width('96lpx')
            .height('96lpx')
          Text(this.totalMenu.userName)
            .fontSize('36lpx')
            .fontWeight(FontWeight.Bold)
            .margin({ left: '12lpx' })
            .flexGrow(1)
          Text(this.totalMenu.userNumber.toString())
            .fontSize('32lpx')
            .margin({ right: '11plx' })

        }
        .height('150lpx')
      }
      if (this.totalMenu.anotherUserNumber > 0) {
        Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
          Image(this.totalMenu.anotherUserImg)
            .width('96lpx')
            .height('96lpx')
          Text(this.totalMenu.anotherUserName)
            .fontSize('36lpx')
            .fontWeight(FontWeight.Bold)
            .margin({ left: '12lpx' })
            .flexGrow(1)
          Text(this.totalMenu.anotherUserNumber.toString())
            .fontSize('32lpx')
            .margin({ right: '11plx' })

        }
        .height('150lpx')
      }
    }
    .margin({ top: '12lpx' })
    .borderRadius('16lpx')
    .padding({ left: '3%', right: '3%', top: '2%' })
    .backgroundColor('#FFFFFF')
  }
}
4.2自定義彈框

1)通過(guò)**@CustomDialog**裝飾器來(lái)創(chuàng )建自定義彈窗,使用方式可參考 [自定義彈窗];

2)規則彈窗效果如下,彈窗組成由一個(gè)[Image]和兩個(gè)[Text]豎向排列組成;

所有我們可以在build()下使用[Flex]容器來(lái)包裹,組件代碼如下:

@CustomDialog
struct SubmitDialog {
  private controller: CustomDialogController

  build() {
    Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center }) {
      Flex({ justifyContent: FlexAlign.Center }) {
        Image($r("app.media.icon_success"))
          .width('100lpx')
          .height('80lpx')
      }
      .flexGrow(1)

      Text('下單成功')
        .fontSize('36lpx')
        .fontColor('#000000')
        .flexGrow(1)
      Text('*溫馨提示:菜品具體售賣(mài)情況請以店面實(shí)際情況為準哦~')
        .fontSize('22lpx')
        .opacity(0.6)
        .fontColor('#000000')
        .padding({ left: '10lpx', right: '10lpx' })
    }
    .height('300lpx')
    .width('100%')
    .padding({ top: '50lpx', bottom: '20lpx' })

  }
}

? 3)在@entry創(chuàng )建CustomDialogController對象并傳入彈窗所需參數,設置點(diǎn)擊允許點(diǎn)擊遮障層退出,通過(guò)open()方法,顯示彈窗;

SubmitDialog: CustomDialogController = new CustomDialogController({
    builder: SubmitDialog(),
    autoCancel: true
  })
aboutToAppear() {
  
    this.remoteData.createManager(() = > {
      let self = this;
      var data;
      if (JSON.stringify(self.remoteData.dataItem).length > 0) {
      	data = self.remoteData.dataItem;
        CommonLog.info("======submit==" + data[0].submit);
        if (data[0].submit == "submitOk") {
          this.SubmitDialog.open()
        }
      }
    }, "com.distributed.order", "submit")
  }

5. 添加分布式流轉

分布式流轉需要在同一網(wǎng)絡(luò )下通過(guò) [DeviceManager組件]進(jìn)行設備間發(fā)現和認證,獲取到可信設備的deviceId調用 [featureAbility].startAbility ,即可把應用程序流轉到另一設備。

1)創(chuàng )建DeviceManager實(shí)例;

2)調用實(shí)例的startDeviceDiscovery(),開(kāi)始設備發(fā)現未信任設備;

3)設置設備狀態(tài)監聽(tīng)on('deviceFound',callback),獲取到未信任設備,并用discoverList變量進(jìn)行維護;

4)傳入未信任設備參數,調用實(shí)例authenticateDevice方法,對設備進(jìn)行PIN碼認證;

5)若是已信任設備,可通過(guò)實(shí)例的getTrustedDeviceListSync()方法來(lái)獲取設備信息;

6)將設備信息中的deviceId傳入[featureAbility].startAbility方法,實(shí)現流轉;

7)流轉接收方可通過(guò)[featureAbility].getWant()獲取到發(fā)送方攜帶的數據;

項目中將上面設備管理封裝至RemoteDeviceManager,通過(guò)RemoteDeviceManager的四個(gè)方法來(lái)動(dòng)態(tài)維護deviceList設備信息列表,實(shí)現分布式流轉只需要在deviceList中獲取deviceId,然后調用featureAbility.startAbility并攜帶數據,即可實(shí)現分布式流轉。

RemoteDeviceManager

6.分布式數據管理

[分布式數據管理]要求兩個(gè)或多個(gè)設備在同一網(wǎng)絡(luò ),才能監聽(tīng)到數據庫的改變,從而渲染頁(yè)面;開(kāi)發(fā)步驟:

1)創(chuàng )建一個(gè)KVManager對象實(shí)例,用于管理數據庫對象;

2)通過(guò)指定Options和storeId,創(chuàng )建并獲取KVStore數據庫,如下是參數說(shuō)明;需要先通過(guò)createKVManager構建一個(gè)KVManager實(shí)例;

參數名類(lèi)型必填說(shuō)明
storeIdstring數據庫唯一標識符,長(cháng)度不大于[MAX_STORE_ID_LENGTH]。
options[Options]創(chuàng )建KVStore實(shí)例的配置信息。

3)KVStore數據庫實(shí)例, KVStore.put提供增加數據的方法,如下是參數說(shuō)明;

參數名類(lèi)型必填說(shuō)明
keystring要添加數據的key,不能為空且長(cháng)度不大于[MAX_KEY_LENGTH]。
valueUint8Arraystringnumber
callbackAsyncCallback回調函數。

4) KVStore數據庫實(shí)例,KVStore.on訂閱指定類(lèi)型的數據變更通知;一般監聽(tīng)遠端設備變化,再進(jìn)行相應操作達到分布式數據共享的效果;

本項目通過(guò)storeId 值不同,創(chuàng )建了兩個(gè)數據庫,分別是MenuListDistributedData類(lèi)和SubmitData類(lèi);

MenuListDistributedData是將完整訂單添加到分布式數據庫

@Component
struct TotalInfo {
  @Consume TotalMenu: any[];
  private total: number = 0;
  private amount: number = 0;
  private remoteData: MenuListData

  aboutToAppear() {
    for (var index = 0; index < this.TotalMenu.length; index++) {
      this.total = this.total + this.TotalMenu[index].price * this.TotalMenu[index].quantity
      this.amount = this.amount + this.TotalMenu[index].quantity
    }
  }

  build() {
    Flex({ direction: FlexDirection.Row, alignItems: ItemAlign.Center }) {
      Stack({ alignContent: Alignment.Center }) {
        Image($r("app.media.icon_cart"))
          .width('96lpx')
          .height('96lpx')
          .margin({ left: '22lpx' })
        Text(this.amount.toString())
          .backgroundColor('#F84747')
          .borderRadius('30plx')
          .fontSize('24plx')
          .textAlign(TextAlign.Center)
          .fontColor('#FFFFFF')
          .width('50lpx')
          .height('50lpx')
          .margin({ left: '100lpx', bottom: '85lpx' })
      }
      .width('150lpx')
      .height('150lpx')

      Text('¥')
        .fontSize('22lpx')
        .fontColor('#006A3A')
        .margin({ left: '22lpx' })
      Text(this.total.toString())
        .fontSize('40lpx')
        .fontColor('#006A3A')
        .flexGrow(1)
      Text('點(diǎn)好了')
        .height('100%')
        .width('35%')
        .fontColor('#FFFFFF')
        .backgroundColor('#F84747')
        .textAlign(TextAlign.Center)
    }
    .onClick(() = > {
      this.remoteData.putData("menu_list", this.TotalMenu)
    })
    .width('100%')
    .height('10%')
    .backgroundColor('#FFFFFF')
  }
}

SubmitData在訂單結算是點(diǎn)擊下單,將submitOk 添加到數據庫;

@Component
struct SubmitList {
  private remoteData: SubmitData
  private SubmitOK: any[] = [
    {
      submit: "submitOk"
    }
  ];

  build() {
    Flex({ alignItems: ItemAlign.Center, justifyContent: FlexAlign.Center }) {
      Text('下單')
        .fontSize('36lpx')
        .fontColor('#FFFFFF')
    }
    .width('100%')
    .height('10%')
    .backgroundColor('#F84747')
    .onClick(() = > {
      this.remoteData.putData("submit", this.SubmitOK)
    })
    .margin({ top: '5%' })
  }
}

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權轉載。文章觀(guān)點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習之用,如有內容侵權或者其他違規問(wèn)題,請聯(lián)系本站處理。 舉報投訴
  • 數據庫
    +關(guān)注

    關(guān)注

    7

    文章

    3628

    瀏覽量

    63689
  • 鴻蒙
    +關(guān)注

    關(guān)注

    55

    文章

    1971

    瀏覽量

    42223
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1914

    瀏覽量

    29498
  • OpenHarmony
    +關(guān)注

    關(guān)注

    24

    文章

    3448

    瀏覽量

    15333
收藏 人收藏

    評論

    相關(guān)推薦

    HarmonyOS開(kāi)發(fā) XstoryMaker快速書(shū)寫(xiě)劇本場(chǎng)景動(dòng)畫(huà)

    ,關(guān)注HarmonyOS的原因很簡(jiǎn)單,就是JS語(yǔ)言可以做原生手機APP開(kāi)發(fā),于去年年底上架了一款自己的HarmonyOS手機APP——Xst
    的頭像 發(fā)表于 09-14 09:30 ?1078次閱讀

    HarmonyOS應用開(kāi)發(fā)-編譯、調試、應用發(fā)布資料

    編譯構建是將HarmonyOS應用的源代碼、資源、第三方庫等打包生成HAP或者APP的過(guò)程。其中,HAP可以直接運行在真機設備或者模擬器中;APP則是用于應用上架到華為應用市場(chǎng)。DevEco
    發(fā)表于 09-21 16:29

    HarmonyOS開(kāi)發(fā)跨設備的鴻蒙(HarmonyOSApp

    是圓形(如智能手表),這就給開(kāi)發(fā)App帶來(lái)了麻煩?,F在幾乎每一個(gè)智能設備廠(chǎng)商,如Apple、華為都面臨這個(gè)問(wèn)題。這就要求我們開(kāi)發(fā)App盡可能適合更多的智能設備。當然,最簡(jiǎn)單,最直接的
    發(fā)表于 11-02 15:18

    HarmonyOS開(kāi)發(fā)跨設備的鴻蒙(HarmonyOSApp

    手表),這就給開(kāi)發(fā)App帶來(lái)了麻煩?,F在幾乎每一個(gè)智能設備廠(chǎng)商,如Apple、華為都面臨這個(gè)問(wèn)題。這就要求我們開(kāi)發(fā)App盡可能適合更多的智能設備。當然,最簡(jiǎn)單,最直接的方式是為每一類(lèi)
    發(fā)表于 11-03 16:54

    開(kāi)發(fā)跨設備的鴻蒙(HarmonyOSApp

    的屏幕,有的是橫向的屏幕,有的帶觸摸功能,有的不帶觸摸功能,甚至有的設備的屏幕是圓形(如智能手表),這就給開(kāi)發(fā)App帶來(lái)了麻煩?,F在幾乎每一個(gè)智能設備廠(chǎng)商,如Apple、華為都面臨這個(gè)問(wèn)題。這就
    發(fā)表于 11-13 09:38

    手把手教你上架HarmonyOS應用

    鴻蒙相關(guān)應用的開(kāi)發(fā)者們,同時(shí)也歡迎與各位感興趣的讀者一起學(xué)習 HarmonyOS 開(kāi)發(fā),相互交流、共同進(jìn)步。上架 HarmonyOS 應用我將分為以下六個(gè)步驟講解:申請訪(fǎng)問(wèn)證書(shū)管理
    發(fā)表于 12-17 18:24

    手把手教你上架HarmonyOS應用

    鴻蒙相關(guān)應用的開(kāi)發(fā)者們,同時(shí)也歡迎與各位感興趣的讀者一起學(xué)習 HarmonyOS 開(kāi)發(fā),相互交流、共同進(jìn)步。上架 HarmonyOS 應用我將分為以下六個(gè)步驟講解:申請訪(fǎng)問(wèn)證書(shū)管理
    發(fā)表于 12-18 09:39

    如何優(yōu)雅地開(kāi)發(fā)HarmonyOS APP應用

    ` 本帖最后由 軟通動(dòng)力HOS 于 2021-3-10 15:29 編輯 研究HarmonyOS有一段時(shí)間了,今天主要結合自己多年的項目開(kāi)發(fā)經(jīng)驗和各種技術(shù)棧結合HarmonyOS APP
    發(fā)表于 03-10 15:13

    戈帥 開(kāi)發(fā)HarmonyOS APP《拼夕夕》演示

    戈帥 開(kāi)發(fā)HarmonyOS APP《拼夕夕》演示
    發(fā)表于 08-28 17:39

    淺析HarmonyOS APP和HAP的組成合集

    對于鴻蒙開(kāi)發(fā)的初學(xué)者而言,了解 HarmonyOS 的一些基礎理論知識尤為重要。本篇文章匯總了關(guān)于鴻蒙移動(dòng)應用開(kāi)發(fā)的重要基礎知識——HarmonyOS
    發(fā)表于 03-22 15:27

    harmonyOS開(kāi)發(fā)APP如何訪(fǎng)問(wèn)Webservice?

    我接到一個(gè)項目,需要用到HarmonyOS開(kāi)發(fā)APP做為移動(dòng)手機查詢(xún)和收到報警數據,具體是這樣的,在C/S加B/S的系統框架下我們有數據庫服務(wù)器和Web服務(wù)器,有widows桌面應用和Web瀏覽器
    發(fā)表于 03-28 10:14

    HarmonyOS APP打包運行和調試應用開(kāi)發(fā)步驟

    在進(jìn)行HarmonyOS應用開(kāi)發(fā)前,您應該掌握HarmonyOS應用的邏輯結構。HarmonyOS應用發(fā)布形態(tài)為APP Pack(Appli
    發(fā)表于 05-24 14:27

    HarmonyOS/OpenHarmony應用開(kāi)發(fā)-PageAbility開(kāi)發(fā)體驗

    功能簡(jiǎn)介PageAbility是具備ArkUI實(shí)現的Ability,是開(kāi)發(fā)者具體可見(jiàn)并可以交互的Ability實(shí)例。開(kāi)發(fā)者通過(guò)IDE創(chuàng )建Ability時(shí),IDE會(huì )自動(dòng)創(chuàng )建相關(guān)模板代碼
    發(fā)表于 12-08 11:03

    HarmonyOS/OpenHarmony應用開(kāi)發(fā)-bindContextMenu綁定菜單選項

    ;) } .width('100%') .height('100%')}}附件【*附件:HarmonyOSOpenHarmony應用開(kāi)發(fā)-bindContextMenu綁定菜單選項.docx】
    發(fā)表于 03-24 11:10

    基于HarmonyOS的分鏡頭App開(kāi)發(fā)技術(shù)詳解

    《分鏡頭App》的創(chuàng )作靈感來(lái)源于殷冬的日常觀(guān)察,他發(fā)現平常人們在自拍時(shí),往往會(huì )用前置攝像頭,由于像素、取景景別等因素的限制,前攝拍出來(lái)的效果往往不是很理想;此外,當我們幫別人拍照時(shí),對方也無(wú)法實(shí)時(shí)
    的頭像 發(fā)表于 08-26 17:59 ?1826次閱讀
    基于<b class='flag-5'>HarmonyOS</b>的分鏡頭<b class='flag-5'>App</b><b class='flag-5'>開(kāi)發(fā)</b>技術(shù)詳解
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看