往期推文全新看点
- 鸿蒙(HarmonyOS)北向开发知识点记录~
- 鸿蒙(OpenHarmony)南向开发保姆级知识点汇总~
- 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?
- 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~
- 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?
- 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?
- 记录一场鸿蒙开发岗位面试经历~
- 持续更新中……
介绍
本示例通过自定义Span类型,在Text组件中使用ForEach遍历,根据不同的Span类型生成不同样式和功能的Span组件,实现部分文本高亮和超链接。
效果图预览
使用说明
- 点击超链接,根据链接类型出现相应提示弹窗。
- 长按消息卡片出现提示弹窗。
实现思路
- 定义 CustomSpanType 枚举类型,此处定义了 Normal、Hashtag、Mention、VideoLink 和 DetailLink 五种类型。
export enum CustomSpanType {
Normal, // 普通文本,不含任何特殊格式或标记
Hashtag, // 话题标签
Mention, // @提及
VideoLink, // 视频链接
DetailLink // 正文详情
}
- 创建 CustomSpan 数据类,用于表示不同类型的 Span 对象。
export class CustomSpan {
type: CustomSpanType; // 文本类型
content: string; // 文本内容
url?: string; // 跳转的链接地址
constructor(type: CustomSpanType = CustomSpanType.Normal, content: string, url?: string) {
this.type = type;
this.content = content;
if (url) {
this.url = url;
}
}
}
- 使用 Text 组件结合 ForEach 方法遍历 spans 中的 CustomSpan 对象,根据不同的 Span 类型生成不同样式和功能的 Span 组件。
Text() {
ForE