【ArkTS】Watch装饰器

@Watch装饰器,相当于Vue中的监听器 以及 React中使用useEffect监听变量

使用@Watch装饰器,可以监听一个数据的变化,并进行后续的响应。
使用方法:
@Watch(‘回调函数’),写在@State装饰器后(其实写在前面也行,但是写到后面更加清晰也符合规范)。

@State @Watch('change') baseNumber: number = 1
change(){
    this.res = Math.pow(this.baseNumber,this.pow)
}

注意:回调函数中一定不能直接操作监听的数据,会造成死循环

下面是一个综合案例

@Entry
@Component

struct UseWatch {
  // 将监听器写到@State装饰器后面
  @State @Watch('change') baseNumber: number = 1
  @State pow: number = 2
  @State res: number = 1
  change(){
    this.res = Math.pow(this.baseNumber,this.pow)
  }
  build() {
      Column(){
        Text(`基数:${this.baseNumber}`)
          .fontSize(40)
          .onClick(() => {
            this.baseNumber++
          })
        Divider()
        Text(`次幂:${this.pow}`)
          .fontSize(40)
          .onClick(() => {
            this.pow ++
          })
        Divider()
        Text(`结果:${this.res}`)
          .fontSize(40)
      }
      .width('100%')
      .height('100%')
      .justifyContent(FlexAlign.Center)
  }
}

运行发现,点击 基数 时,即@Watch监听的数据发生变化时,执行了change函数
在这里插入图片描述
但是点击 次幂 时,由于@Watch监听的数据未发生改变,所以没执行change函数
在这里插入图片描述
再次点击 基数 时,重新执行change函数
在这里插入图片描述

### ArkTS 日志信息 示例 在ArkTS中,日志信息主要用于调试和问题诊断。为了确保应用程序的高效性和简洁性,在开发过程中适当使用日志功能是非常重要的[^4]。 #### 示例代码展示如何正确地添加日志: ```typescript @Component struct DebugLoggingExample { build() { Button('Log Info', { type: ButtonType.Normal, stateEffect: true }) .onClick(() => { console.log("Button clicked at " + new Date().toISOString()); // 记录按钮点击时间戳 // 执行其他必要的业务逻辑... }); } } ``` 此示例展示了当按钮被按下时记录一条简单的日志消息,其中包括当前的时间戳。这有助于了解用户的交互行为以及可能存在的异常情况。 ### 日志信息的主要用途 1. **性能监控** - 使用`console.time()` 和 `console.timeEnd()` 方法来测量特定操作所需的时间,以便识别潜在瓶颈并优化应用性能[^1]。 2. **错误排查** - 当遇到未预期的行为或崩溃时,可以通过查看详细的日志文件找到根本原因所在。例如,利用`try...catch`结构捕获异常并将堆栈跟踪写入日志中。 3. **资源管理** - 跟踪对象创建与销毁的过程可以帮助预防内存泄漏等问题的发生。比如,在组件卸载之前清理定时器、取消订阅等动作都值得记录下来以供后续分析[^5]。 4. **状态变化通知** - 对于带有复杂状态的应用来说,监听重要属性的变化并通过日志形式报告给开发者是一项非常有用的功能。像`@Watch`这样的装饰器能够简化这项工作流程[^2]。 ### 日志的最佳实践建议 - 只有在必要的情况下才启用详细的日志级别(如debug),而在生产环境中通常只需要保留警告及以上级别的信息。 - 避免过度依赖控制台输出作为唯一的反馈机制;考虑集成第三方工具来进行更深入的日志管理和可视化呈现。 - 定期审查现有日志策略的有效性,并根据实际需求调整其配置参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

田本初

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值