吐槽一下鸿蒙系统设计的状态管理组件
一. 定义和作用
状态管理组件其本质作用用来修饰状态变量,这样可以观察到变量在组件内的改变,还可以在不同组件层级间传递,其设计初衷挺好。在声明式UI编程框架中,UI是程序状态的运行结果,这套状态管理机制最重要的作用就是提供运行时的状态变化所带来的UI的重新渲染。
二.状态管理装饰器
V1
组件拥有的状态
- @State装饰器:组件内状态
- @Prop装饰器:父子单向同步
- @Link装饰器:父子双向同步
- @Provide装饰器和@Consume装饰器:与后代组件双向同步
- @Observed装饰器和@ObjectLink装饰器:嵌套类对象属性变化
应用拥有的状态
- LocalStorage:页面级UI状态存储
- AppStorage:应用全局的UI状态存储
- PersistentStorage:持久化存储UI状态
- Environment:设备环境查询
问题来了,现在又出来个V2
V2
组件拥有的状态
- @ObservedV2装饰器和@Trace装饰器:类属性变化观测
- @ComponentV2装饰器:自定义组件
- @Local装饰器:组件内部状态
- @Param:组件外部输入
- @Once:初始化同步一次
- @Event装饰器:规范组件输出
- @Provider装饰器和@Consumer装饰器:跨组件层级双向同步
- @Monitor装饰器:状态变量修改监听
- @Computed装饰器:计算属性
- @Type装饰器:标记类属性的类型
其他状态管理
- AppStorageV2: 应用全局UI状态存储
- PersistenceV2: 持久化储存UI状态
- !!语法:双向绑定
- 自定义组件冻结功能
- Repeat:子组件复用
- getTarget接口:获取状态管理框架代理前的原始对象
- makeObserved接口:将非观察数据变为可观察数据
三.吐槽
看到这么多状态是不是懵逼了,来看看官方如何解释这个V2。
通俗讲就是V1的plus版本,然后对于之前项目用的V1,是否能混用V2,官方也很贴心的给出了说明:
4条指引,通俗讲就是建议大家赶紧切换V2,功能更强大,最重要是后面有可能V1不能用了,同样的话语是不是很熟悉,作为一个系统最核心的状态API管理机制,这种翻篇的改变机制感觉很不成熟,保不齐后面再出现个V3、V4...