软件教程 2025年08月6日
0 收藏 0 点赞 227 浏览 2148 个字
摘要 :

文章目录 @State装饰器:组件内状态 @Observed @ObjectLink 本文主要讲解关于鸿蒙ArkTS装饰器@State、@Observed和@ObjectLink详解相关内容,让我们来一起学习下吧! @S……




  • @State装饰器:组件内状态
  • @Observed
  • @ObjectLink

本文主要讲解关于鸿蒙ArkTS装饰器@State、@Observed和@ObjectLink详解相关内容,让我们来一起学习下吧!

@State装饰器:组件内状态

@State状态数据具有以下特征:

  • 1、支持多种类型:允许class、number、boolean、string强类型的按值和按引用类型。允许这些强类型构成的数组,即Array、Array、Array、Array不允许object和any
  • 2、支持多实例:组件不同实例的内部状态数据独立。
  • 3、内部私有:标记为@State的属性是私有变量,只能在组件内访问。
  • 4、需要本地初始化:必须为所有@State变量分配初始值,将变量保持未初始化可能导致框架行为未定义。
  • 5、 创建自定义组件时支持通过状态变量名设置初始值:在创建组件实例时,可以通过变量名显式指定@State状态属性的初始值。

@State向@Link传参时,用**$**引用@State父组件变量的值,如:

ComponentA({ highScore: $highScore })

@State向@Prop传参时,用**this.**引用@State父组件变量的值,如:

ComponentA({ highScore: this.highScore })

@Observed

  • @Observed应用于类,表示该类中的数据变更被UI页面管理,例如:
@Observed class ClassA {}

@ObjectLink

  • @ObjectLink应用于被@Observed所装饰类的对象(变量),例如:
@ObjectLink a: ClassA

使用要求

  • 1、@Observed 用于类,@ObjectLink 用于变量。
  • 2、@ObjectLink装饰的变量类型必须为类(class type)。
  • 3、类要被@Observed装饰器所装饰。
    • 不支持简单类型参数,可以使用@Prop进行单向同步。
  • 4、@ObjectLink装饰的对象变量是不可变的,但可以修改对象里面变量的值。
    • 属性的改动是被允许的,当改动发生时,如果同一个对象被多个@ObjectLink变量所引用,那么所有拥有这些变量的自定义组件都会被通知去重新渲染。
  • 5、@ObjectLink装饰的变量不可设置默认值。
    • 必须让父组件中有一个由@State、@Link、@StorageLink、@Provide或@Consume所装饰变量参与的TS表达式进行初始化。
  • 6、@ObjectLink装饰的变量是私有变量,只能在组件内访问。

代码示例:

@Observed
class ClassA {
  public name : string;
  public c: number;
  constructor(c: number, name: string = \'\') {
    this.name = name;
    this.c = c;
  }
}
 
class ClassB {
  public a: ClassA;
  constructor(a: ClassA) {
    this.a = a;
  }
}
 
@Component
struct ViewA {
  label : string = \"ep1\";
  @ObjectLink a : ClassA;
  build() {
    Column() {
      Text(`ViewA [${this.label}]: a.c=${this.a.c}`)
        .fontSize(20)
      Button(`+1`)
        .width(100)
        .margin(2)
        .onClick(() => {
          this.a.c += 1;
        })
      Button(`reset`)
        .width(100)
        .margin(2)
        .onClick(() => {
          this.a = new ClassA(0); // 错误:ObjectLink装饰的变量a是不可变的
        })
    }
  }
}
 
@Entry
@Component
struct ViewB {
  @State b : ClassB = new ClassB(new ClassA(10));
  build() {
    Flex({direction: FlexDirection.Column, alignItems: ItemAlign.Center}) {
      ViewA({label: \"ViewA #1\", a: this.b.a})
      ViewA({label: \"ViewA #2\", a: this.b.a})
 
      Button(`ViewB: this.b.a.c += 1` )
        .width(320)
        .margin(4)
        .onClick(() => {
          this.b.a.c += 1;
        })
      Button(`ViewB: this.b.a = new ClassA(0)`)
        .width(240)
        .margin(4)
        .onClick(() => {
          this.b.a = new ClassA(0);
        })
      Button(`ViewB: this.b = new ClassB(ClassA(0))`)
        .width(240)
        .margin(4)
        .onClick(() => {
          this.b = new ClassB(new ClassA(0));
        })
    }
  }
}

以上就是关于鸿蒙ArkTS装饰器@State、@Observed和@ObjectLink详解相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/6607.html

管理员

相关推荐
2025-08-06

文章目录 一、Promise基础回顾 二、Promise 与 axios 结合使用场景及方法 (一)直接返回 axios …

269
2025-08-06

文章目录 一、模块初始化时的内部机制 二、常见导出写法的差异分析 (一)写法一:module.exports…

107
2025-08-06

文章目录 一、ResizeObserver详解 (一)ResizeObserver是什么 (二)ResizeObserver的基本用法 …

683
2025-08-06

文章目录 一、前期准备工作 (一)下载相关文件 (二)安装必要工具 二、处理扣子空间生成的文件…

338
2025-08-06

文章目录 一、官方文档 二、自动解包的数据类型 ref对象:无需.value即可访问 reactive对象:保持…

371
2025-08-06

文章目录 一、Hooks的工作原理 二、在if语句中使用Hook会出什么岔子? 三、React官方的Hook使用规…

843
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号