鸿蒙HarmonyOS状态管理组件吐槽

吐槽一下鸿蒙系统设计的状态管理组件

一. 定义和作用

状态管理组件其本质作用用来修饰状态变量,这样可以观察到变量在组件内的改变,还可以在不同组件层级间传递,其设计初衷挺好。在声明式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...

核心吐槽点:一个优秀的系统或者平台,最重要的是什么:通用性,稳定性,扩展性,但是至少目前从鸿蒙上面没看出来,感觉整个系统架构一开始就没有一个大的架构设计,从而导致后面不断地修改补丁,很多API中途加上,后面莫名其妙的就废弃了,没有一点严谨性,说不用就不用,感觉很随意,但坑的都是生态建设者,重复适配不严谨的轮子,这不是一个好现象,本身生态就不好,现在好不容易慢慢做起来了,应该重视生态建设,包括用户和开发者,否则这样下去,很容易形成空中楼阁,不敢往深处扒。
相关推荐
鸿蒙布道师30 分钟前
鸿蒙NEXT开发设备相关工具类(ArkTs)
android·ios·华为·harmonyos·arkts·鸿蒙系统·huawei
用户0082283981363 小时前
遵循HarmonyOS NEXT UI设计原则,打造卓越用户体验
harmonyos
molong9313 小时前
Android开发鸿蒙环境问题记录
android·华为·harmonyos
我是小智5 小时前
鸿蒙开发04界面渲染
harmonyos·鸿蒙
survivorsfyh12 小时前
zsh: command not found: hdc - 鸿蒙 HarmonyOS Next
华为·harmonyos·鸿蒙
qq_5537603214 小时前
HarmonyOS:WebView 控制及 H5 原生交互实现
华为·harmonyos·鸿蒙
IC拓荒者17 小时前
华为海思IC前端中后端(COT&XPU)岗位笔试机考题
华为·数字后端零基础·海思ic笔试题·海思实习·海思实习题·海思秋招笔试题·海思cot招聘
别说我什么都不会21 小时前
OpenHarmony实战开发之测试适配的HDF驱动
嵌入式·harmonyos·领域驱动设计
Star7681 天前
鸿蒙系统中实现保存pdf至本地
app·harmonyos
威哥爱编程1 天前
HarmonyOS NEXT 实现滑动拼图验证码功能
华为·harmonyos·arkts