HarmonyOS page如何监听数据变化

page如何监听一个单例中的数据变化,page的struct不支持registerDelegate。目前的解决方案是给page一个object成员进行监听,是否有更合适的方案。aboutToAppear注册的监听,理论上是否需要在aboutToDisappear中移除?

export interface LoginDelegate {
  onLogin(): void

  onLogout(): void
}

export class LoginService {
  private static instance: LoginService;
  delegateArray: Array<LoginDelegate> = []

  registerDelegate(delegate: LoginDelegate): void {
    this.delegateArray.push(delegate)
  }

  // 后面是一些业务接口,比如登录、登出
  // 当登录状态发生变化时通过delegate发出
}

class LoginPageAgent implements LoginDelegate {
  @Track status: LoginStatus = LoginStatus.LoggedOut;

  onLogin(): void {
    this.status = LoginStatus.LoggedIn
  }

  onLogout(): void {
    this.status = LoginStatus.LoggedOut
  }
}

@Component
struct LoginPage {
  @State agent: LoginPageAgent = new LoginPageAgent()

  aboutToAppear(): void {
    LoginService.shared().registerDelegate(this.agent)
  }

  build() {
    Column({}) {
      if (this.agent.status == LoginStatus.LoggedIn) {
        Text(`已登录`)
      } else {
        this.loginInput()
      }
    }
  }
}
HarmonyOS
2024-12-25 12:12:08
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
fox280

可以使用事件订阅实现监听数据变化,参考文档:https://developer.huawei.com/consumer/cn/doc/harmonyos-references-V5/js-apis-inner-application-eventhub-V5

取消监听的位置随意,只要能在页面销毁之前取消就可以了。

分享
微博
QQ
微信
回复
2024-12-25 13:05:36
相关问题
HarmonyOS 装饰器数据变化监听
73浏览 • 1回复 待解决
HarmonyOS数据数据变化是否可以监听
755浏览 • 1回复 待解决
HarmonyOS 如何监听组件自身尺寸变化
265浏览 • 1回复 待解决
HarmonyOS 如何监听某个变量是否变化
213浏览 • 1回复 待解决
如何监听window大小的变化
700浏览 • 1回复 待解决
如何监听窗口大小的变化
2520浏览 • 1回复 待解决
HarmonyOS 如何监听系统主题变化
283浏览 • 1回复 待解决
HarmonyOS onMemoryLevel监听内存变化
60浏览 • 1回复 待解决
HarmonyOS 网络变化监听失效
218浏览 • 1回复 待解决
HarmonyOS 如何监听到音频焦点的变化
298浏览 • 1回复 待解决
如何监听数组内对象属性变化
2578浏览 • 1回复 待解决
HarmonyOS 音频设备变化监听
410浏览 • 1回复 待解决
如何监听文件或文件目录的变化
1904浏览 • 1回复 待解决
HarmonyOS 监听Page第一帧上屏
298浏览 • 1回复 待解决
HarmonyOS 监听所有page的生命周期
800浏览 • 1回复 待解决
HarmonyOS 怎么在page监听返回键
50浏览 • 1回复 待解决