HarmonyOS 鸿蒙Next 多个@Prop变化顺序问题

发布于 1周前 作者 eggper 来自 鸿蒙OS

HarmonyOS 鸿蒙Next 多个@Prop变化顺序问题
我子组件有两个@Prop ,在父组件中使用后,在父组件更新数据,但是先更新的却在后更新的变化之后变化。请问这个@Prop变化时没有先后顺序? 代码如下、

子组件

[@Prop](/user/Prop) 
@Watch('stateChange') 
state: QuantityOfElectricityEnum 

[@Prop](/user/Prop) 
progress: number 

stateChange() { 
  switch (this.state) { 
    case QuantityOfElectricityEnum.CHARGE: 
    case QuantityOfElectricityEnum.ERROR: 
      this.canvas.clearRect(2, 2.5, this.drawWidth, this.drawHeight); 
      break 
    case QuantityOfElectricityEnum.SHOW_BATTERY: 
      TinLog.e('--------------------drawProgress--------stateChange---------'
        + this.progress) 
      this.drawProgress() 
      break 
  } 
}

父组件:

let bp = this.subscribe!!.bp 
this.charging = this.subscribe.bp > 100 ? 100 : bp 

if (bp == 238 || bp == 239 || (bp == 240 && bpError)) { 
  this.changingState = QuantityOfElectricityEnum.ERROR 
} else if (this.subscribe.wm == 2) { 
  this.changingState = QuantityOfElectricityEnum.CHARGE 
} else { 
  this.changingState = QuantityOfElectricityEnum.SHOW_BATTERY 
} 

使用:  
QuantityOfElectricity({ 
  progress: this.charging, 
  state: this.changingState 
})  

最终发现必须给子组件progress也添加@Watch('stateChange')才能保证正确,但先后顺序还是不能保证,
请问如何保证[@Prop](/user/Prop)更新数据的先后顺序。

更多关于HarmonyOS 鸿蒙Next 多个@Prop变化顺序问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

@Prop更新数据的先后顺序是按自组件的修改的顺序来进行的,watch回调方法最好还是用不同名的,用同名的话,可以传名字区分一下,在某个变量变化的时候再触发

更多关于HarmonyOS 鸿蒙Next 多个@Prop变化顺序问题的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS(鸿蒙)系统中,关于@Prop变化顺序的问题,主要涉及到数据绑定和组件属性更新的机制。在鸿蒙的开发框架中,@Prop用于定义组件的属性,这些属性通常与数据模型绑定,当数据模型发生变化时,组件的属性也会相应更新。

关于多个@Prop变化顺序的处理,鸿蒙系统会按照属性设置的先后顺序或者数据依赖关系进行更新。如果多个@Prop之间存在依赖关系,系统会先更新依赖项,再更新依赖于此依赖项的属性。这种机制确保了数据的一致性和组件的正确渲染。

然而,在某些复杂场景下,如果开发者希望明确控制@Prop的更新顺序,可能需要通过编程手段来实现,例如使用状态管理或数据流的工具来精确控制数据的更新时机。

此外,值得注意的是,鸿蒙系统的组件框架会尽量优化更新过程,以减少不必要的重绘和性能开销。因此,开发者在大多数情况下不需要过分关注@Prop的变化顺序,除非遇到了特定的性能问题或渲染错误。

如果问题依旧没法解决请联系官网客服,官网地址是:https://www.itying.com/category-93-b0.html

回到顶部