HarmonyOS @builder方法的ui不刷新
@Entry
@Component
export struct AAMainPage {
// ViewB中有@State装饰的ClassA[]
@State arrA: ClassA[] = [new ClassA(0), new ClassA(0)];
build() {
Column() {
hahah({ a: this.arrA[0] })
ForEach(this.arrA, (item: ClassA, index: number) => {
hahah({ a: item }).backgroundColor('red')
}, (item: ClassA, index: number) => index + "")
this.testBuilder(this.arrA[0])
Button(`ViewB: item property in middle`)
.width(320)
.margin(10)
.onClick(() => {
this.arrA[0].c = 10;
})
}
}
@Builder
testBuilder($$: ClassA) {
Text($$.c + " builder")
}
// @Builder
// testBuilder(a: ClassA) {
// Text(a.c + " builder")
// }
}
@Preview
@Component
export struct hahah {
@ObjectLink a: ClassA
build() {
Text(this.a.c + " 123213")
}
}
let NextID: number = 1;
@Observed
class ClassA {
public id: number;
public c: number;
constructor(c: number) {
this.id = NextID++;
this.c = c;
}
}
HarmonyOS
赞
收藏 0
回答 1
待解决
相关问题
HarmonyOS 自定义builder方法, 参数是按引用传递, 当状态值修改时, 不触发builder方法, 不会刷新UI
509浏览 • 1回复 待解决
HarmonyOS @Builder UI刷新问题
36浏览 • 1回复 待解决
HarmonyOS UI不刷新
30浏览 • 1回复 待解决
HarmonyOS UI不刷新问题
30浏览 • 1回复 待解决
IF条件变化后UI不刷新
783浏览 • 1回复 待解决
状态装饰器 ui不刷新的问题
2476浏览 • 1回复 待解决
HarmonyOS 想要通过@State修饰的变量刷新@Builder方法内的UI,只能通过引用传递参数吗?
47浏览 • 1回复 待解决
HarmonyOS 是否有种主动刷新UI的方法
37浏览 • 1回复 待解决
HarmonyOS @Builder的内容如何刷新
78浏览 • 1回复 待解决
修改ForEach使用的数据对象,UI不刷新
1875浏览 • 1回复 待解决
使用LazyForEach渲染语法渲染组件,UI不刷新。
1130浏览 • 1回复 待解决
HarmonyOS 懒加载列表更改属性UI不刷新
37浏览 • 1回复 待解决
HarmonyOS能否实现服务卡片刷新卡片UI不拉起应用
494浏览 • 1回复 待解决
HarmonyOS 使用@builder和@builderParam时,@builder中的ui不会动态更新
423浏览 • 1回复 待解决
HarmonyOS 解析Json数据添加到数据源不刷新UI
598浏览 • 2回复 待解决
HarmonyOS 主线程刷新UI
294浏览 • 1回复 待解决
backgroud()方法使用@State修饰的状态变量值更新后未能触发不同的@builder方法刷新
2257浏览 • 1回复 待解决
HarmonyOS 按Refresh组件示例代码,在不刷新的常规场景时候,builder内的组件也会露出一半
327浏览 • 1回复 待解决
UI预览不会自动刷新, 且刷新较慢
710浏览 • 1回复 待解决
HarmonyOS LazyForEach问题刷新UI问题
71浏览 • 1回复 待解决
HarmonyOS使用@ObjectLink 数据不刷新
800浏览 • 2回复 待解决
HarmonyOS @State状态量刷新、@Builder不会响应变化
49浏览 • 0回复 待解决
#鸿蒙通关秘籍#在鸿蒙 NEXT 中如何使用全局 @Builder 方法来定义可复用的 UI 结构?
133浏览 • 1回复 待解决
HarmonyOS UI 未刷新问题
572浏览 • 0回复 待解决
调用@Builder装饰的函数默认按值传递。当传递的参数为状态变量时,状态变量的改变不会引起@Builder方法内的UI刷新。所以当使用状态变量的时候,推荐使用按引用传递。此时,引用传递的值必须要为@State修饰。
详见:https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/arkts-builder-V5#参数传递规则
修改建议:
目前@Builder设计模式是这样,刷新内容必须用引用传递。示例中的@observed 修饰的实体类采用了构造方法,不能作为引用传递。只要是引用传递就可以,不一定非要$$。按引用传递参数时,如果在@Builder方法内调用自定义组件,ArkUI提供$$作为按引用传递参数的范式。如果在@Builder方法内调用自定义组件或者其他@Builder方法,ArkUI提供$$作为按引用传递参数的范式。