多態(tài)樣式
設(shè)置組件不同狀態(tài)下的樣式。
說明:
開發(fā)前請(qǐng)熟悉鴻蒙開發(fā)指導(dǎo)文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]
從API Version 8開始支持。后續(xù)版本如有新增內(nèi)容,則采用上角標(biāo)單獨(dú)標(biāo)記該內(nèi)容的起始版本。
屬性
| 名稱 | 參數(shù)類型 | 描述 |
|---|---|---|
| stateStyles | StateStyles | 設(shè)置組件不同狀態(tài)的樣式。 從API version 9開始,該接口支持在ArkTS卡片中使用。 |
StateStyles接口說明
從API version 9開始,該接口支持在ArkTS卡片中使用。
| 名稱 | 類型 | 必填 | 描述 |
|---|---|---|---|
| normal | ()=>void | 否 | 組件無狀態(tài)時(shí)的樣式。 |
| pressed | ()=>void | 否 | 組件按下狀態(tài)的樣式。 |
| disabled | ()=>void | 否 | 組件禁用狀態(tài)的樣式。 |
| focused | ()=>void | 否 | 組件獲焦?fàn)顟B(tài)的樣式。 |
| clicked | ()=>void | 否 | 組件點(diǎn)擊狀態(tài)的樣式。 |
| selected10+ | ()=>void | 否 | 組件選中狀態(tài)的樣式。HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿 |
![]() |
示例
// xxx.ets
@Entry
@Component
struct StyleExample {
@State isEnable: boolean = true
@Styles pressedStyles() {
.backgroundColor("#ED6F21")
.borderRadius(10)
.borderStyle(BorderStyle.Dashed)
.borderWidth(2)
.borderColor("#33000000")
.width(120)
.height(30)
.opacity(1)
}
@Styles disabledStyles() {
.backgroundColor("#E5E5E5")
.borderRadius(10)
.borderStyle(BorderStyle.Solid)
.borderWidth(2)
.borderColor("#2a4c1919")
.width(90)
.height(25)
.opacity(1)
}
@Styles normalStyles() {
.backgroundColor("#0A59F7")
.borderRadius(10)
.borderStyle(BorderStyle.Solid)
.borderWidth(2)
.borderColor("#33000000")
.width(100)
.height(25)
.opacity(1)
}
build() {
Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Center }) {
Text("normal")
.fontSize(14)
.fontColor(Color.White)
.opacity(0.5)
.stateStyles({
normal: this.normalStyles,
})
.margin({ bottom: 20 })
.textAlign(TextAlign.Center)
Text("pressed")
.backgroundColor("#0A59F7")
.borderRadius(20)
.borderStyle(BorderStyle.Dotted)
.borderWidth(2)
.borderColor(Color.Red)
.width(100)
.height(25)
.opacity(1)
.fontSize(14)
.fontColor(Color.White)
.stateStyles({
pressed: this.pressedStyles,
})
.margin({ bottom: 20 })
.textAlign(TextAlign.Center)
Text(this.isEnable == true ? "effective" : "disabled")
.backgroundColor("#0A59F7")
.borderRadius(20)
.borderStyle(BorderStyle.Solid)
.borderWidth(2)
.borderColor(Color.Gray)
.width(100)
.height(25)
.opacity(1)
.fontSize(14)
.fontColor(Color.White)
.enabled(this.isEnable)
.stateStyles({
disabled: this.disabledStyles,
})
.textAlign(TextAlign.Center)
Text("control disabled")
.onClick(() = > {
this.isEnable = !this.isEnable
console.log(`${this.isEnable}`)
})
}
.width(350).height(300)
}
}

審核編輯 黃宇
-
鴻蒙
+關(guān)注
關(guān)注
60文章
2841瀏覽量
45335
發(fā)布評(píng)論請(qǐng)先 登錄
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【圖片邊框設(shè)置】 通用屬性
HarmonyOS/OpenHarmony應(yīng)用開發(fā)-ArkTS的聲明式開發(fā)范式
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【按鍵事件】
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【邊框設(shè)置】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【背景設(shè)置】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【透明度設(shè)置】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【顯隱控制】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【形狀裁剪】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【柵格設(shè)置】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【菜單控制】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【組件標(biāo)識(shí)】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【分布式遷移標(biāo)識(shí)】 通用屬性
鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【組件內(nèi)容模糊】 通用屬性

鴻蒙ArkTS聲明式開發(fā):跨平臺(tái)支持列表【多態(tài)樣式】 通用屬性

評(píng)論