
【HarmonyOS 5】makeObserved接口详解 原创
【HarmonyOS 5】makeObserved接口详解
一、makeObserved接口是什么?
makeObserved 接口(API version 12 起可用)用于将非观察数据转为可观察数据,适用于三方包类、@Sendable 装饰的类、JSON.parse 返回的对象、collections.Array/Set/Map 等场景。
不支持 undefined和null类型。以及V1 状态装饰器(@State/@Prop)及已被观察的数据,避免双重代理。主要处理的是Object类型,非Object类型,例如基本数据类型number这种,都不支持。
需要注意的是,makeObserved主要针对的是V2的使用场景。因为它是为了解决 @Trace/@ObservedV2 无法覆盖的痛点观察需求。比如从网络请求返回的JSON对象,需要在UI上进行观测操作。就可使用makeObserved。所以V1使用@State就可解决的问题,不用考虑这个。
二、makeObserved如何使用?
(1)接口调用
使用及其简单,只需要导入import { UIUtils } from '@kit.ArkUI’进行接口调用接口。麻烦的是识别你的入参是否支持观测监听。
(2)可从操作的业务场景进行区分,符合以下三种场景一般可操作:
1、三方SDK包中的数据类,这种情况下需要UI可监测,因为无法手动添加@Trace,一般可支持。
【该场景较为简单,参考上面示例即可】
2、@Sendable装饰的类,因为禁止动态修改属性,一般可支持。
3、 JSON.parse返回的匿名对象,一般是网络请求反馈,一般可支持。
三、注意
-
getTarget问题:
通过getTarget获取原始对象后修改属性,不会触发UI刷新(需操作代理对象) -
兼容性错误:
与@State等V1装饰器混用会抛异常,需使用V2装饰器(@Local/@Provide等)
