鸿蒙——Builder 和 BuildParam的区别?Builder和Component的区别?  ...

打印 上一主题 下一主题

主题 564|帖子 564|积分 1692

1.Builder 和 BuildParam的区别?

Builder是当前组件的UI复用结构, BuilderParams是接收父组件传入的UI复用结构, 传过来的类型是UI复用结构类型。
Builder传值,想要响应式必须是对象,如果是基础数据类型,不具备响应式。
● 他们都是修饰符,Builder是将一个函数修饰为轻量UI复用的函数,在Builder修饰的函数中可以实现ArkUl的应用。 Builder的用法有全局builder另有局部builder,全局builder不得当做状态更新,全局builder在鸿蒙4.0中被导出使用,支持在Next版本中使用。 
Builder的传值有基础类型传值和引用类型传值,引用类型传值才气具备响应式的特点
● BuilderParam类似于前端范畴中Vue中的插槽slot,可以传入UI的结构,支持自界说组件的传入结构,首选在子组件中界说BuilderParam,在父组件中传入BuilderParam对应的函数,该函数可以没有builder修饰,但是必须调用一个builder修饰的函数。
BuilderParam中有一种尾随闭包的写法,就是组件( )后面的大括号可以传入内容,有两个前提 1.必须只有一个BuilderParam 2. BuilderParam没有接收参数的需求才可以
 
 
2.@Builder 和@Component 的区别? 

,@Builder 和 @Component 是两种差别的装饰器,它们用于界说和构造 UI 结构,但各自有差别的特点和用途。
@Builder  
● @Builder 是一种自界说构建函数,它答应开辟者将重复使用的 UI 元素抽象成一个方法,然后在 build() 方法中多次调用,以完成 UI 结构的复用。
● @Builder 方法可以界说在组件内或全局。在组件内界说的 @Builder 方法可以通过 this 访问当前组件的属性和方法,而全局的 @Builder 方法则不能
● @Builder 方法具有两种参数传递机制:按值传递和按引用传递。按引用传递时,如果传递的参数为状态变量,则状态变量的变化会触发 @Builder 方法内部 UI 的刷新;按值传递时则不会。
● @Builder 方法不能界说自己的状态变量,而自界说组件可以界说状态变量。
@Component  
● @Component 用于封装较大的组件,它可以包罗复杂的 UI 结构和业务逻辑。
● @Component 可以界说自己的状态变量,并且可以包罗多个 @Builder 方法来复用 UI 结构。
● @Component 可以在 build() 方法中直接使用 @Builder 方法来构建 UI,也可以通过 @BuilderParam 装饰器来界说组件的属性,这些属性可以作为 UI 结构的占位符,在创建组件时传入详细的内容。
综上所述,@Builder 更得当用于轻量级的 UI 结构复用,而 @Component 更得当用于构建完备的、具有状态管理的组件。如果复用的 UI 结构没有状态,推荐使用 @Builder;如果需要界说状态变量,则应该使用 @Component.

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

卖不甜枣

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表