HarmonyOS5鸿蒙开发常用组件介绍

一、文本类组件​

  1. Text

    • ​用途​​:显示纯文本内容,支持样式自定义(字体、颜色、对齐等)

    • ​示例​​:

      scss 复制代码
      Text("Hello HarmonyOS")
        .fontSize(20)
        .fontColor(Color.Black)
        .textAlign(TextAlign.Center)
  2. TextInput

    • ​用途​​:单行文本输入框,支持密码模式、占位符提示等

    • ​关键属性​​:

      scss 复制代码
      TextInput({ placeholder: "请输入内容" })
        .type(InputType.Password)  // 密码输入
        .placeholderColor(Color.Gray)
  3. TextArea

    • ​用途​​:多行文本输入框,支持自动换行和字数统计

    • ​示例​​:

      scss 复制代码
      TextArea()
        .height(100)
        .maxLength(200)  // 限制输入长度
        .showCounter(true)  // 显示字数统计

🕹️ ​​二、交互类组件​

  1. Button

    • ​用途​​:触发操作的按钮,支持样式定制和点击事件

    • ​示例​​:

      scss 复制代码
      Button("提交", { type: ButtonType.Normal })
        .backgroundColor(0x317aff)
        .onClick(() => { /* 处理逻辑 */ })
  2. Toggle

    • ​用途​​:开关控件,支持勾选框/开关样式切换

    • ​示例​​:

      javascript 复制代码
      Toggle({ type: ToggleType.Switch, isOn: true })
        .onChange((isOn) => { console.log(`开关状态: ${isOn}`) })
  3. CheckBox & Radio

    • ​用途​ ​:多选框(CheckBox)和单选框(Radio),用于选项选择

    • ​示例​​:

      php 复制代码
      // 多选框
      CheckBox({ name: 'option1' }).select(true)
      // 单选框
      Radio({ value: 'A', group: 'choices' }).checked(true)

🧩 ​​三、布局容器组件​

  1. Column & Row

    • ​用途​ ​:纵向(Column)和横向(Row)排列子组件,支持主轴/交叉轴对齐

    • ​示例​​:

      scss 复制代码
      Column() {
        Text("顶部文本")
        Button("底部按钮")
      }.justifyContent(FlexAlign.SpaceBetween)  // 两端对齐
  2. List

    • ​用途​ ​:滚动列表容器,适用于长列表数据展示(需配合 ListItem 使用)

    • ​示例​​:

      scss 复制代码
      List() {
        ForEach(dataArray, (item) => {
          ListItem() { Text(item.name) }
        })
      }.scrollBar(BarState.Off)  // 隐藏滚动条
  3. Swiper

    • ​用途​​:轮播图容器,支持自动播放和循环切换

    • ​示例​​:

      scss 复制代码
      Swiper() {
        ForEach(bannerList, (item) => {
          Image(item.imageSrc).objectFit(ImageFit.Contain)
        })
      }.autoPlay(true).loop(true)
  4. Scroll

    • ​用途​​:可滚动容器,当内容超出可视区域时支持滚动

    • ​注意​ ​:嵌套 List 时需明确指定子组件宽高以优化性能。


🖼️ ​​四、媒体与图像组件​

  1. Image

    • ​用途​​:显示本地或网络图片,支持缩放和裁剪模式

    • ​示例​​:

      scss 复制代码
      Image($r('app.media.logo'))  // 加载资源图片
        .objectFit(ImageFit.Cover)  // 覆盖整个容器
        .borderRadius(10)  // 圆角

📊 ​​五、高级容器组件​

  1. Grid & GridItem

    • ​用途​ ​:网格布局(Grid)及其子项容器(GridItem),用于瀑布流展示

    • ​限制​ ​:GridItem 必须作为 Grid 的子组件使用。

  2. WaterFlow & FlowItem

    • ​用途​ :瀑布流布局(WaterFlow)及其子项(FlowItem),适用于不规则内容排列

⚙️ ​​六、自定义组件​

通过 ​@Component​ 装饰器创建可复用的 UI 单元,组合系统组件实现业务逻辑

scss 复制代码
@Component
struct CustomCard {
  build() {
    Column() {
      Text("自定义卡片标题").fontSize(18)
      Button("详情").onClick(() => { /* 跳转逻辑 */ })
    }
  }
}

💎 ​​核心组件总结表​

​类别​ ​组件​ ​核心功能​ ​典型场景​
​文本输入​ Text, TextInput 显示/编辑文本内容 表单输入、内容展示
​交互控制​ Button, Toggle 触发操作、状态切换 提交表单、开关设置
​布局容器​ Column, List 排列子组件、支持滚动 列表页、详情页布局
​媒体展示​ Image, Swiper 图片/轮播图展示 Banner 广告、商品图集
​高级容器​ Grid, WaterFlow 网格/瀑布流布局 图片墙、商品分类页

更多组件用法详见 HarmonyOS 官方文档 或参考 ArkUI 组件指南。实际开发中可组合使用(如 List + ListItem 构建动态列表,Swiper + Image 实现轮播图)

相关推荐
前端不太难16 小时前
鸿蒙 App 的“无状态 System”设计
华为·状态模式·harmonyos
UnicornDev18 小时前
【Flutter x HarmonyOS 6】魔方计时APP——计时逻辑实现
flutter·华为·harmonyos·鸿蒙·鸿蒙系统
AlbertZein1 天前
ImageKnifePro 源码解读:鸿蒙图片加载框架全貌
harmonyos
AlbertZein1 天前
鸿蒙工程化:build-profile.json5 逐字段解析
harmonyos
前端技术1 天前
鸿蒙ArkTS 自定义底部导航栏(Tabs+@Builder 极简实现)
harmonyos·鸿蒙
Swift社区1 天前
为什么“页面跳转”在鸿蒙 PC 上是错误设计?
华为·harmonyos
熬夜敲代码的小N2 天前
鸿蒙PC开发者必备!GitNext深度测评:一站式Git管理工具
git·华为·harmonyos
秋の本名2 天前
第一章 鸿蒙生态架构与开发理念
华为·wpf·harmonyos
Ww.xh2 天前
鸿蒙系统中HTML与Vue集成方案
vue.js·html·harmonyos
前端不太难2 天前
鸿蒙游戏 CI/CD:为什么你还在手动打包?
游戏·ci/cd·harmonyos