鸿蒙卡片传值app到卡片

复制代码
WidgetCard.ets
复制代码
@Entry
@Component
struct WidgetCard {
  @State num: number = 0

  @LocalStorageProp('formId')
  @Watch('updataFormId')
  formId:string=''

  updataFormId(){
    // 卡片向app传参
    postCardAction(this, {
      action: 'call',
      abilityName: 'EntryAbility',
      params:{
        method:'updataFormId',
        num:this.formId
      }
    });
  }

  build() {
    Row() {
      Column() {

        Text('ID:'+this.formId)

        Button(this.num + '++').onClick(() => {
          this.num++
          postCardAction(this, {
            action: 'call',
            abilityName: 'EntryAbility',
            params:{
              method:'updataNum',
              num:this.num
            }
          });
        })
      }.width('100%')
    }
    .height('100%')
    .onClick(() => {
      postCardAction(this, {
        action: 'router', //跳转事件
        abilityName: 'EntryAbility',

      });
    })
  }
}

获取卡片id

在卡片的entryability中:EntryFormAbility

复制代码
export default class EntryFormAbility extends FormExtensionAbility {
  onAddForm(want: Want) {
    // Called to return a FormBindingData object.
    let formData = '';
    return formBindingData.createFormBindingData({
      // form id
      formId:want.parameters!['ohos.extra.param.key.form_identity']as string
    });
  }

在app的entryability中:

复制代码
class Params implements rpc.Parcelable{
  marshalling(dataOut: rpc.MessageSequence): boolean {
    return true
  }

  unmarshalling(dataIn: rpc.MessageSequence): boolean {
    return true
  }

}

class CaraParam{
  num:number=0
  formId:string=''
}

export default class EntryAbility extends UIAbility {
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');

    this.callee.on('updataNum',(data)=>{
      let res=JSON.parse(data.readString())as CaraParam
      AppStorage.setOrCreate('num',res.num)
      return new Params()
    })

    // 卡片创建时,调用了updataFormId,此时这里就会被触发,然后app将值传过去
    this.callee.on('updataFormId',(data)=>{
      let res=JSON.parse(data.readString())as CaraParam
      // AppStorage.setOrCreate('num',res.formId)
      // 数据可以写到首选项中存储

      // 把最新的数据推过去
      formProvider.updateForm(res.formId,formBindingData.createFormBindingData({
        num:AppStorage.get('num')
      }))
      return new Params()
    })
  }
相关推荐
鸣弦artha24 分钟前
BottomSheet底部抽屉组件详解
flutter·华为·harmonyos
zilikew1 小时前
Flutter框架跨平台鸿蒙开发——文字朗读器APP的开发流程
flutter·华为·harmonyos
lbb 小魔仙1 小时前
【Harmonyos】开源鸿蒙跨平台训练营DAY3:HarmonyOS + Flutter + Dio:从零实现跨平台数据清单应用完整指南
flutter·开源·harmonyos
Miguo94well2 小时前
Flutter框架跨平台鸿蒙开发——歌词制作器APP的开发流程
flutter·华为·harmonyos·鸿蒙
b2077212 小时前
Flutter for OpenHarmony 身体健康状况记录App实战 - 体重趋势实现
python·flutter·harmonyos
b2077212 小时前
Flutter for OpenHarmony 身体健康状况记录App实战 - 个人中心实现
android·java·python·flutter·harmonyos
BlackWolfSky2 小时前
鸿蒙中级课程笔记3—ArkUI进阶1—属性动画与转场动画
华为·harmonyos
Miguo94well3 小时前
Flutter框架跨平台鸿蒙开发——科目一题目练习APP的开发流程
flutter·华为·harmonyos
天才少年曾牛3 小时前
【无标题】
android·frameworks
2601_949575863 小时前
Flutter for OpenHarmony二手物品置换App实战 - 自定义组件实现
android·javascript·flutter