HarmonyOS/OpenHarmony原生应用-ArkTS万能卡片组件Span

作为Text组件的子组件,用于显示行内文本的组件。无子组件

一、接口

Span(value: string | Resource)

从API version 9开始,该接口支持在ArkTS卡片中使用。

参数:

|-------|--------------------|----|-------|
| 参数名 | 参数类型 | 必填 | 参数描述 |
| value | string | Resource | 是 | 文本内容。 |

二、属性

通用属性方法仅支持通用文本样式。

|---------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------|
| 名称 | 参数类型 | 描述 |
| decoration | { type: TextDecorationType, color?: ResourceColor } | 设置文本装饰线样式及其颜色。 默认值:{ type: TextDecorationType.None color:Color.Black } 从API version 9开始,该接口支持在ArkTS卡片中使用。 |
| letterSpacing | number | string | 设置文本字符间距。取值小于0,字符聚集重叠,取值大于0且随着数值变大,字符间距越来越大,稀疏分布。 从API version 9开始,该接口支持在ArkTS卡片中使用。 |
| textCase | TextCase | 设置文本大小写。 默认值:TextCase.Normal 从API version 9开始,该接口支持在ArkTS卡片中使用。 |

三、事件

通用事件仅支持点击事件。

说明

由于Span组件无尺寸信息,因此点击事件返回的ClickEvent对象的target属性无效。

四、示例

// xxx.ets

@Entry

@Component

struct SpanExample {

build() {

Flex({ direction: FlexDirection.Column, alignItems: ItemAlign.Start, justifyContent: FlexAlign.SpaceBetween }) {

Text('Basic Usage').fontSize(9).fontColor(0xCCCCCC)

Text() {

Span('In Line')

Span(' Component')

Span(' !')

}

Text() {

Span('This is the Span component').fontSize(12).textCase(TextCase.Normal)

.decoration({ type: TextDecorationType.None, color: Color.Red })

}

// 文本横线添加

Text('Text Decoration').fontSize(9).fontColor(0xCCCCCC)

Text() {

Span('I am Underline-span').decoration({ type: TextDecorationType.Underline, color: Color.Red }).fontSize(12)

}

Text() {

Span('I am LineThrough-span')

.decoration({ type: TextDecorationType.LineThrough, color: Color.Red })

.fontSize(12)

}

Text() {

Span('I am Overline-span').decoration({ type: TextDecorationType.Overline, color: Color.Red }).fontSize(12)

}

// 文本字符间距

Text('LetterSpacing').fontSize(9).fontColor(0xCCCCCC)

Text() {

Span('span letter spacing')

.letterSpacing(0)

.fontSize(12)

}

Text() {

Span('span letter spacing')

.letterSpacing(-2)

.fontSize(12)

}

Text() {

Span('span letter spacing')

.letterSpacing(3)

.fontSize(12)

}

// 文本大小写展示设置

Text('Text Case').fontSize(9).fontColor(0xCCCCCC)

Text() {

Span('I am Lower-span').fontSize(12)

.textCase(TextCase.LowerCase)

.decoration({ type: TextDecorationType.None })

}

Text() {

Span('I am Upper-span').fontSize(12)

.textCase(TextCase.UpperCase)

.decoration({ type: TextDecorationType.None })

}

}.width('100%').height(250).padding({ left: 35, right: 35, top: 35 })

}

}

五、场景

适合做文本特效的各种卡片。

本文根据HarmonyOS官方文档整理

相关推荐
坚果派·白晓明1 小时前
【鸿蒙PC三方库移植适配框架解读系列】第一篇:Lycium C/C++ 三方库适配 — 概述与环境配置
c语言·开发语言·c++·harmonyos·开源鸿蒙·三方库·c/c++三方库
小雨青年3 小时前
鸿蒙 HarmonyOS 6 | Pura X Max 鸿蒙原生适配 04:开合切换后的选中状态保持
华为·harmonyos
阿钱真强道3 小时前
22 鸿蒙LiteOS 互斥锁(Mutex)实战教程:多任务共享资源保护
harmonyos·鸿蒙·互斥·rk·liteos·瑞芯微·rk2206
大师兄66683 小时前
HarmonyOS 卡片 UI 三种玩法:普通卡片、动效卡片、Canvas 卡片
harmonyos·arkts·formkit·动效卡片·canvas卡片
特立独行的猫a8 小时前
鸿蒙 PC 命令行工具迁移实战 · 直播PPT
android·华为·harmonyos·vcpkg·三方库移植·鸿蒙pc
想你依然心痛8 小时前
HarmonyOS 6(API 23)实战:基于悬浮导航、沉浸光感与Face AR & Body AR的“灵犀智投“——PC端沉浸式AR量化交易分析工作台
华为·ar·harmonyos·悬浮导航·沉浸光感
特立独行的猫a8 小时前
鸿蒙 PC 三方库移植实战 · 直播课件(详细教案)
华为·harmonyos·移植·鸿蒙pc·opendesk
xmdy586610 小时前
Flutter+开源鸿蒙实战|企业级工具APP Day2 全局网络封装与 Dio 拦截器实战(鸿蒙兼容版)
flutter·开源·harmonyos
xmdy586610 小时前
Flutter+开源鸿蒙实战:企业级工具类APP开发教程(含第三方库适配)
flutter·开源·harmonyos
richard_yuu11 小时前
鸿蒙Stage模型实战|心晴驿站分层架构与隐私安全设计
安全·架构·harmonyos