相关问题
#鸿蒙通关秘籍#如何为自定义组件实现自定义布局?
231浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何通过组件复用提升鸿蒙应用组件创建效率?
335浏览 • 1回复 待解决
#鸿蒙通关秘籍# 在鸿蒙开发中,自定义组件如何实现跨文件复用,有哪些步骤?
219浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何实现可变内容的自定义组件?
283浏览 • 1回复 待解决
#鸿蒙通关秘籍#通过自定义组件冻结功能如何优化鸿蒙应用的页面渲染时间?
229浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何通过鸿蒙自定义组件实现属性传递和事件传递?
294浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何自定义Toggle组件的样式?
212浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何实现鸿蒙应用中组件的跨文件样式复用?
304浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何实现自定义组件方式的全局弹窗封装?
235浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何使用TextInput组件实现自定义安全键盘?
438浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何自定义鸿蒙图片组件的布局参数?
303浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何通过BaseNavigation实现自定义导航栏
266浏览 • 1回复 待解决
#鸿蒙通关秘籍#关于App首页加载时长,如何通过自定义组件优化?
128浏览 • 1回复 待解决
自定义组件实现了组件复用后,如果使用@Reuseable这个组件的复用范围是什么?
641浏览 • 0回复 待解决
#鸿蒙通关秘籍#如何在NodeContainer中实现自定义组件节点的切换?
326浏览 • 1回复 待解决
#鸿蒙通关秘籍#Tabs组件中如何实现自定义页面切换动画?
390浏览 • 1回复 待解决
#鸿蒙通关秘籍#在HarmonyOS Next应用中实现自定义弹窗组件的动画效果
271浏览 • 1回复 待解决
#鸿蒙通关秘籍#想做好管理自定义组件的代码复用性,怎么做
188浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何自定义鸿蒙Tabs组件的导航栏样式?
320浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何在鸿蒙中使用Text组件实现自定义Tab效果?
280浏览 • 1回复 待解决
#鸿蒙通关秘籍#HML自定义组件模板的使用
258浏览 • 1回复 待解决
#鸿蒙通关秘籍# 如何通过Tab组件隐藏自带TabBar并自定义增删页面?
256浏览 • 0回复 待解决
#鸿蒙通关秘籍#鸿蒙应用如何进行组件的跨文件复用?
267浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何查询当前自定义组件的页面信息?
419浏览 • 1回复 待解决
#鸿蒙通关秘籍#如何自定义PullToRefresh组件的下拉刷新动画?
292浏览 • 1回复 待解决
在鸿蒙应用中,通过自定义组件来实现公共组件的复用,步骤如下:
定义自定义组件,支持传入多个
AttributeModifier
:javascript @Component export struct ImageText { @State textOne: AttributeModifier<TextAttribute> = new TextModifier(); @State imageModifier: AttributeModifier<ImageAttribute> = new ImageModifier();
build() { Row() { Image(this.imageSrc) .attributeModifier(this.imageModifier); Text(this.textOneContent) .attributeModifier(this.textOne) .fontColor($r('app.color.orange')); } } }
class ImageModifier implements AttributeModifier<ImageAttribute> { applyNormalAttribute(instance: ImageAttribute): void { instance.width($r('app.float.float_100')); instance.height($r('app.float.float_100')); } }
class TextModifier implements AttributeModifier<TextAttribute> { applyNormalAttribute(instance: TextAttribute): void { instance.fontSize($r('app.float.float_12')); instance.fontColor($r('app.color.orange')); } }
使用组件时,提供定制的
AttributeModifier
实例:javascript @Component export struct ShoppingCart { @State textOne: CommodityText = new CommodityText(TextType.TYPE_ONE, 15); @State imageModifier: ImageModifier = new ImageModifier(100, 100);
build() { ImageText({ item: item, textOne: this.textOne, imageModifier: this.imageModifier, imageSrc: $r('app.media.icon'), }); } }
通过使用自定义组件,开发者可以实现不同页面和场景下的组件复用,减少了冗余代码。