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疑问
2167浏览 • 1回复 待解决
HarmonyOS 关于deliveryWithInstall疑问
2011浏览 • 1回复 待解决
HarmonyOS 关于混淆疑问
1342浏览 • 1回复 待解决
HarmonyOS 关于手动签名疑问
1789浏览 • 1回复 待解决
HarmonyOS 关于NavPathStack疑问
1234浏览 • 1回复 待解决
HarmonyOS UI样式不能封装至其他文件
828浏览 • 1回复 待解决
HarmonyOS 关于DES加解密疑问
1023浏览 • 1回复 待解决
HarmonyOS 关于半模态转场疑问
1090浏览 • 1回复 待解决
关于Wearable开发几个疑问
8975浏览 • 2回复 待解决
关于鸿蒙应用开发疑问?
6526浏览 • 1回复 待解决
HarmonyOS 关于AvPlayer中usage问题疑问
1204浏览 • 1回复 待解决
关于鸿蒙next相关疑问
507浏览 • 0回复 待解决
关于鸿蒙next相关疑问
505浏览 • 0回复 待解决
关于鸿蒙next相关疑问
675浏览 • 2回复 待解决
关于鸿蒙next相关疑问
649浏览 • 0回复 待解决
关于鸿蒙next相关疑问
547浏览 • 0回复 待解决
关于鸿蒙next相关疑问
512浏览 • 0回复 待解决
关于鸿蒙next相关疑问
584浏览 • 1回复 待解决
关于鸿蒙next相关疑问
523浏览 • 0回复 待解决
关于鸿蒙next相关疑问
509浏览 • 0回复 待解决
关于鸿蒙next相关疑问
762浏览 • 1回复 待解决
关于鸿蒙next相关疑问
461浏览 • 0回复 待解决
关于鸿蒙next相关疑问
488浏览 • 0回复 待解决
关于鸿蒙next相关疑问
455浏览 • 0回复 待解决
关于鸿蒙next相关疑问
1236浏览 • 1回复 待解决