HarmonyOS 关于ArkTS UI样式文件的疑问

在API9中,ArkTS UI所创建的样式文件无法跨文件使用。这个在后续的ArkTS UI中是否有支持呢?

HarmonyOS
2024-10-21 10:40:18
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
FengTianYa

当前已有能力实现样式跨文件复用,类似其他平台的viewModifier。

//定义样式文件,MyImageModifier .ets  
import { ImageModifier } from “@ohos.arkui.modifer”;  
class MyImageModifier extends ImageModifier {  
  public syncModeValue?: boolean  
  public cacheModeValue?: boolean  
  override applyNormalAttribute(instance: ImageAttribute): void {  
    super.applyNormalAttribute(instance)  
    // extend logics  
  }  
  syncMode(isSync: boolean) : MyImageModifier {  
    this.syncModeValue = isSync  
    return this  
  }  
  cacheMode(isCached: boolean) : MyImageModifier {  
    this.cacheModeValue = isCached  
    return this  
  }  
}  
//封装自定义组件@Component  
struct MyImage {  
  @Link modifier: MyImageModifier  
  @State src: string  
  build() {  
    Image(this.src)  
      .attributeModifier(this.modifier)  
  }  
  aboutToAppear() {  
    if (this.modifier.syncModeValue) {  
      // do something  
    }  
    if (this.modifier.cacheModeValue) {  
      // do something  
    }  
  }  
}  
//使用自定义组件  
@Entry @Component  
struct Index {  
  @State myImageModifier: MyImageModifier =  
    new MyImageModifier()  
      .syncMode(true)  
      .cacheMode(true)  
      .autoResize(true)  
      .renderMode(ImageRenderMode.Template)  
      .width(100)  
  isSync: boolean = false  
  
  build() {  
    Row() {  
      MyImage({ modifier: this.myImageModifier, src: $r(‘xxxx’) })  
      Button(“Click”).onClick(() => {  
        isSync = !isSync  
        this.myImageModifier.syncMode(isSync)  
      })  
    }  
  }  
}
分享
微博
QQ
微信
回复
2024-10-21 15:13:49
相关问题
HarmonyOS 关于deliveryWithInstall疑问
518浏览 • 1回复 待解决
HarmonyOS关于RichText疑问
679浏览 • 1回复 待解决
HarmonyOS 关于手动签名疑问
384浏览 • 1回复 待解决
关于DependentLayout布局一点疑问
5630浏览 • 1回复 待解决
关于鸿蒙camera外设驱动编写疑问
4451浏览 • 1回复 待解决
HarmonyOS 关于ui设计出稿
236浏览 • 1回复 待解决
请教一下关于Ticktimer 疑问
3398浏览 • 1回复 待解决
鸿蒙怎么实现UI控件样式复用 ?
7636浏览 • 3回复 待解决
关于Java UI Checkbox问题?
5733浏览 • 1回复 待解决
关于鸿蒙应用开发疑问?
5356浏览 • 1回复 待解决
关于Wearable开发几个疑问
7360浏览 • 2回复 待解决
HarmonyOS 关于ArkTS!使用
470浏览 • 1回复 待解决
HarmonyOS 关于调试UI细节相关
217浏览 • 1回复 待解决
HarmonyOS关于TS转ArkTS语法问题
302浏览 • 1回复 待解决
arkts 关于异步问题
205浏览 • 1回复 待解决
关于智能穿戴应用开发几个疑问
10599浏览 • 2回复 待解决
关于Tabs里面tabBar样式问题
289浏览 • 2回复 待解决
关于 JS UI 开发应用问题?
5612浏览 • 1回复 待解决
ArkTS文件和TS文件区别
2306浏览 • 1回复 待解决
如何使用ArkTS编写UI界面?
492浏览 • 1回复 待解决
关于 SO 文件使用问题
138浏览 • 1回复 待解决
关于Java UI拖拽式开发问题
5942浏览 • 1回复 待解决