HarmonyOS(35) @State使用注意事项

@State使用注意事项

注意事项

HarmonyOS鸿蒙学习笔记(5)@State作用说明和简单案例一文中简单介绍了@State的使用方法,但是@State装饰器使用有一些注意事项:在应用开发中,应避免在循环逻辑中频繁读取状态变量,而是应该放在循环外面读取。

反例

java 复制代码
@Entry
@Component
struct Index {
  @State message: string = '';

  build() {
    Column() {
      Button('点击打印日志')
        .onClick(() => {
          for (let i = 0; i < 10; i++) {
            //循环体中使用message
            hilog.info(0x0000, 'TAG', '%{public}s', this.message);
          }
        })
        .width('90%')
        .backgroundColor(Color.Blue)
        .fontColor(Color.White)
        .margin({
          top: 10
        })
    }
    .justifyContent(FlexAlign.Start)
    .alignItems(HorizontalAlign.Center)
    .margin({
      top: 15
    })
  }
}

正例

java 复制代码
@Entry
@Component
struct Index {
  @State message: string = '';

  build() {
    Column() {
      Button('点击打印日志')
        .onClick(() => {
          //循环体外提前访问message变量
          let logMessage: string = this.message;
          for (let i = 0; i < 10; i++) {
            hilog.info(0x0000, 'TAG', '%{public}s', logMessage);
          }
        })
        .width('90%')
        .backgroundColor(Color.Blue)
        .fontColor(Color.White)
        .margin({
          top: 10
        })
    }
    .justifyContent(FlexAlign.Start)
    .alignItems(HorizontalAlign.Center)
    .margin({
      top: 15
    })
  }
}

参考资料

状态管理优秀实践

相关推荐
咸鱼过江32 分钟前
openharmony中HDF驱动框架源码梳理-驱动加载流程
harmonyos·hdf框架
Landy_Jay6 小时前
HarmonyOS:应用文件概述(通俗易懂解释版)
华为·harmonyos
轻口味6 小时前
【每日学点HarmonyOS Next知识】Web跨域资源、Web长按菜单、Web拦截请求、禁止录屏、Base64图片宽高
华为·harmonyos·harmonyosnext
SuperHeroWu76 小时前
【HarmonyOS Next】鸿蒙应用加载SVG文件显示图标
华为·svg·harmonyos·鸿蒙·加载·image·图标
SuperHeroWu710 小时前
【HarmonyOS Next】鸿蒙加固方案调研和分析
华为·harmonyos·加密·应用安全·应用加固
东林知识库10 小时前
鸿蒙NEXT开发-自定义相机拍照
华为·harmonyos
青春路上的小蜜蜂11 小时前
鸿蒙——实操开发自定义Hivigor插件并发布插件
typescript·harmonyos·plugin·hvigor·自定义插件
H.ZWei12 小时前
鸿蒙应用开发—数据持久化之SQLite
数据库·华为·sqlite·harmonyos
别说我什么都不会13 小时前
鸿蒙(HarmonyOS)性能优化实战-启动分析工具Launch Profiler
性能优化·harmonyos
SuperHeroWu713 小时前
【HarmonyOS Next】鸿蒙应用弹框和提示气泡详解(一)
dialog·华为·harmonyos·toast·气泡·自定义弹框