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关于RichText疑问
2226浏览 • 1回复 待解决
HarmonyOS 关于deliveryWithInstall疑问
2110浏览 • 1回复 待解决
HarmonyOS 关于混淆疑问
1407浏览 • 1回复 待解决
HarmonyOS 关于手动签名疑问
1845浏览 • 1回复 待解决
HarmonyOS UI样式不能封装至其他文件
845浏览 • 1回复 待解决
HarmonyOS 关于NavPathStack疑问
1292浏览 • 1回复 待解决
HarmonyOS 关于半模态转场疑问
1109浏览 • 1回复 待解决
HarmonyOS 关于DES加解密疑问
1052浏览 • 1回复 待解决
HarmonyOS 关于AvPlayer中usage问题疑问
1239浏览 • 1回复 待解决
关于Wearable开发几个疑问
9113浏览 • 2回复 待解决
关于鸿蒙应用开发疑问?
6637浏览 • 1回复 待解决
关于鸿蒙next相关疑问
575浏览 • 0回复 待解决
关于鸿蒙next相关疑问
545浏览 • 0回复 待解决
关于鸿蒙next相关疑问
565浏览 • 0回复 待解决
关于鸿蒙next相关疑问
549浏览 • 0回复 待解决
关于鸿蒙next相关疑问
530浏览 • 0回复 待解决
关于鸿蒙next相关疑问
690浏览 • 0回复 待解决
关于鸿蒙next相关疑问
625浏览 • 1回复 待解决
关于鸿蒙next相关疑问
763浏览 • 2回复 待解决
HarmonyOS 关于actionsheet样式问题
1139浏览 • 1回复 待解决
关于鸿蒙next相关疑问
525浏览 • 0回复 待解决
关于鸿蒙next相关疑问
1342浏览 • 1回复 待解决
关于鸿蒙next相关疑问
818浏览 • 1回复 待解决
关于鸿蒙next相关疑问
538浏览 • 0回复 待解决
关于鸿蒙next相关疑问
476浏览 • 0回复 待解决