鸿蒙装饰器的介绍

State装饰器,

State装饰的变量,称为状态变量,与声明式范式中的其他被装饰变量一样,是私有的,只能从组件内部访问,在声明时,必须指定其类型和本地初始化。

Provide装饰器和@Consume装饰器,

其中@provide装饰的变量是在祖先节点中,可以理解为被'提供'给后代的状态变量。@Consume装饰的变量是在后代组件中,去绑定祖先节点提供的变量。

@Provide和@Consume可以通过相同的变量名或者相同的变量别名绑定,变量类型必须相同

\ 复制代码
// 通过相同的变量名绑定
@Provide a: number = 0;
@Consume a: number;

// 通过相同的变量别名绑定
@Provide('a') b: number = 0;
@Consume('a') c: number;

实例

复制代码
// 孙组件
@Component
struct CountDownComponentB {
  @Consume count: number;
  build() {
    Column() {
      Text(`这是孙组件的值:${this.count},改变会影响到父组件。`)
      Row(){
        Button(`+1`).onClick(() => {
          this.count += 1
        })
        Button(`-1`).onClick(() => {
          this.count -= 1
        })
      }
      .justifyContent(FlexAlign.SpaceEvenly)
      .width("100%")
    }
  }
}

// 子组件
@Component
struct CountDownComponentA {
  build() {
    Column() {
      // 孙组件
      CountDownComponentB()
    }
  }
}


// 父组件
@Entry
@Component
struct ParentComponent {
  @Provide count: number = 10;

  build() {
    Column() {
      Text(`这是父组件的值:${this.count},改变会传给孙组件。`)
      Row(){
        Button(`+1`).onClick(() => {
          this.count += 1;
        })
        Button(`-1`).onClick(() => {
          this.count -= 1;
        })
      }
      .justifyContent(FlexAlign.SpaceEvenly)
      .width("100%")

      // 子组件
      CountDownComponentA()

    }
  }
}

watch装饰器:状态变量更改通知

@watch应用于对状态变量的监听。如果开发者需要关注某个状态变量的值是否改变,可以使用@watch为状态变量设置回调函数

当状态变量变化时,@watch回调方法将被调用。@watch在ARKUI框架内吧判断数值有无更新,使用的是严格相等===,当在严格相等为false的情况下,就会触发@watch的回调。

@watch可用于购物车计算总价,或者实现计算器功能等

(ChangedPropertyName?:string)=>void

建议开发者避免无限循环。循环可能是因为在@watch的回调方法里面直接或者间接地修改了同一个状态变量引起的,未来避免循环的产生,建议不要在@watch的回调方法里修改当前装饰的状态变量

/*

  • @Watch 修饰 状态数据
  • 函数中,不要修改被监视的状态变量。 我们要操作的是其他的业务逻辑
  • */
    @Entry
    @Component
    struct WatchDct {
    @State @Watch('change') count: number = 1
    @State @Watch('change') pow: number = 2
    @State res: number = 1

change() {

this.res = Math.pow(this.count, this.pow)

}

build() {

Row() {

Column() {

Text('基数:' + this.count)

.fontSize(50)

.onClick(() => {

this.count++

})

复制代码
    Divider()
    Text(`次幂:${this.pow}`)
      .fontSize(50)
      .onClick(() => {
        this.pow++
      })

    Divider()
    Text("结果:" + this.res)
      .fontSize(50)
  }
  .width('100%')
}
.height('100%')

}

}

相关推荐
island13147 小时前
【C++仿Muduo库#3】Server 服务器模块实现上
服务器·开发语言·c++
茉莉玫瑰花茶7 小时前
LangGraph 介绍
服务器·网络·数据库
mfxcyh8 小时前
如何把对象数据转化为数组
java·服务器·前端
2301_780789668 小时前
云服务器数据会泄露吗?怎么保护云服务器的数据
运维·服务器·tcp/ip·网络安全
2301_780789668 小时前
云服务器被黑能恢复吗?云服务器被黑的解决办法
运维·服务器·网络·安全·web安全
淘小白_TXB21968 小时前
头条百家采集改写发布软件用户使用手册
运维·服务器·头条采集·头条号采集·文章采集·头条采集软件
HwJack209 小时前
HarmonyOS APP开发之解密 ArkTS 状态管理:@State, @Observed, @ObjectLink 三角阵
华为·harmonyos
Web极客码9 小时前
Akismet对WordPress防垃圾评论
服务器·搜索引擎·wordpress
渣渣灰958710 小时前
解决VMware上终端窗口太小问题
运维·服务器·经验分享
谙弆悕博士11 小时前
快速学C语言——第2章:编程规范与代码风格
服务器·c语言·开发语言·经验分享·程序人生·学习方法·业界资讯