16.[HarmonyOS NEXT Column案例一(上)] 使用Column组件构建垂直表单布局的基础指南

简介: 在HarmonyOS NEXT应用开发中,布局是构建用户界面的基础。本教程将详细讲解如何使用Column组件创建垂直排列的表单布局,通过一个登录表单的实例,展示Column组件的基本用法、间距控制和对齐方式等核心知识点。


项目已开源,开源地址: https://gitcode.com/nutpi/HarmonyosNextCaseStudyTutorial , 欢迎fork & star

案例演示


1. 引言

在HarmonyOS NEXT应用开发中,布局是构建用户界面的基础。本教程将详细讲解如何使用Column组件创建垂直排列的表单布局,通过一个登录表单的实例,展示Column组件的基本用法、间距控制和对齐方式等核心知识点。

2. Column组件概述

Column组件是HarmonyOS NEXT中用于垂直排列子组件的容器组件,它基于ArkUI的声明式开发范式,能够简洁高效地构建垂直布局。

2.1 Column组件的基本特性

特性

说明

排列方向

垂直方向(从上到下)

主轴

垂直方向

交叉轴

水平方向

默认尺寸

自适应内容大小

子组件排列

按声明顺序从上到下排列

2.2 Column组件的基本语法

Column(options?: { space?: number | string }) {
  // 子组件
}

其中,options参数可以设置子组件之间的间距:

  • space: 子组件之间的垂直间距,可以是数字(表示vp单位)或字符串(可以指定不同单位)

3. 案例分析:登录表单的结构

我们将通过分析一个登录表单的实现,来学习Column组件的使用。这个表单包含以下元素:

  1. 标题文本("用户登录")
  2. 用户名输入框
  3. 密码输入框
  4. 登录按钮

3.1 组件结构

首先,让我们看一下整个组件的基本结构:

@Component
export struct FormExample {
    @State username: string = ''
    @State password: string = ''
    build() {
        Column({ space: 20 }) {
            // 子组件
        }
        .justifyContent(FlexAlign.Center)
        .width('100%')
        .padding({ top: 40, left: 24, right: 24 })
        .backgroundColor(0xFFFFFF)
        .height('100%')
    }
}

这个结构中:

  • @Component装饰器:标识这是一个自定义组件
  • @State装饰器:定义了组件的状态变量,用于存储用户名和密码
  • build()方法:定义组件的UI结构
  • Column({ space: 20 }):创建一个垂直布局容器,子组件之间的间距为20vp

4. Column组件的参数设置

在我们的案例中,Column组件的初始化和属性设置如下:

Column({ space: 20 }) // 子组件垂直间距20vp
{
    // 子组件
}
.justifyContent(FlexAlign.Center)
.width('100%')
.padding({ top: 40, left: 24, right: 24 })
.backgroundColor(0xFFFFFF)
.height('100%') // 撑满屏幕高度

4.1 参数详解

参数/属性

作用

space

20

设置子组件之间的垂直间距为20vp

justifyContent

FlexAlign.Center

设置子组件在主轴(垂直方向)上居中对齐

width

'100%'

设置Column宽度占父容器的100%

padding

{ top: 40, left: 24, right: 24 }

设置内边距:上40vp,左右各24vp

backgroundColor

0xFFFFFF

设置背景色为白色

height

'100%'

设置高度占父容器的100%,撑满屏幕

4.2 间距控制

在Column组件中,有两种方式控制间距:

  1. 通过space参数:设置所有子组件之间的统一间距
Column({ space: 20 })
  1. 通过margin属性:为特定子组件设置外边距(在本例中未使用,但是一种常见的间距控制方法)

4.3 对齐方式

Column组件提供了多种对齐方式控制:

  1. 主轴对齐(垂直方向):通过justifyContent属性控制
  • 本例中使用FlexAlign.Center使子组件在垂直方向居中对齐
  1. 交叉轴对齐(水平方向)
  • 整体对齐:可以通过Column的alignItems属性控制(本例未显式设置)
  • 单个子组件对齐:通过子组件的alignSelf属性控制(如标题文本的左对齐)

5. 总结

本教程的第一部分,我们详细介绍了Column组件的基本概念、参数设置、间距控制和对齐方式。通过登录表单的案例,展示了如何使用Column组件创建垂直布局的基础知识。

在下一部分中,我们将继续深入探讨表单中各个子组件的实现细节,包括Text、TextInput和Button组件的属性设置和样式定制,以及如何通过这些组件构建一个完整的登录表单界面。

相关文章
|
3月前
|
API 开发者 索引
HarmonyOS API 15 新晋导航点组件Indicator详解
本节介绍HarmonyOS API 15新增的导航点组件Indicator的特性和用法,支持圆点和数字两种导航样式。示例基于DevEco Studio 5.0.5,展示如何不依赖Swiper组件独立显示导航点。通过IndicatorComponentController控制翻页,设置初始索引、样式、循环、总数及方向等属性,并处理索引变化事件。代码示例详细解析各属性与事件的功能,适用于API Version 15及以上版本,支持ArkTS卡片和元服务使用。源码托管于《跟老卫学HarmonyOS开发》GitHub仓库。
63 1
|
3月前
|
定位技术 UED
70. [HarmonyOS NEXT 实战案例九] 旅游景点网格布局(下)
在上一篇教程中,我们学习了如何使用GridRow和GridCol组件实现基本的旅游景点网格布局。本篇教程将在此基础上,深入探讨如何优化布局、添加交互功能,以及实现更多高级特性,打造一个功能完善的旅游景点应用。
86 1
|
3月前
|
开发者 容器
HarmonyOS Next快速入门:Button组件
本教程摘自《HarmonyOS Next快速入门》,聚焦HarmonyOS应用开发中的Button组件。Button支持胶囊、圆形和普通三种类型,可通过子组件实现复杂功能,如嵌入图片或文字。支持自定义样式(边框弧度、文本样式、背景色等)及点击事件处理。示例代码展示了不同类型按钮的创建与交互逻辑,助开发者快速上手。适合HarmonyOS初学者及对UI组件感兴趣的开发者学习。
432 0
|
3月前
|
开发者
HarmonyOS Next快速入门:Image组件
本教程摘自《HarmonyOS Next快速入门》,专注于HarmonyOS应用开发中的Image组件使用。Image组件支持多种图片格式(如png、jpg、svg等),可渲染本地资源、网络图片、媒体库文件及PixelMap像素图。通过设置`objectFit`属性,实现不同缩放类型;利用`fillColor`属性调整矢量图颜色。示例代码涵盖本地、网络及资源图片的加载与样式设置,同时需在`module.json5`中声明网络权限以加载外部资源。适合开发者快速掌握HarmonyOS图像展示功能。
418 0
|
3月前
|
监控 JavaScript 前端开发
🎉 Harmony OS Next里的Web组件:网页加载的全流程掌控手册
本文详细解析了Harmony OS Next中ArkUI Web组件的九大生命周期回调,帮助开发者全面掌控网页加载流程。从组件初始化到加载完成,再到异常处理与性能优化,每个阶段都配有具体代码示例和注意事项。内容涵盖关键回调(如aboutToAppear、onPageBegin)的使用场景、网页加载进度监控(FCP/FMP/LCP)、以及前端页面优化实践。通过本文,开发者可以高效管理网页加载过程,提升应用性能与用户体验。
181 0
|
3月前
|
API UED 开发者
Harmony OS Next玩转多层级手势事件:当组件遇上“套娃”,触摸该怎么分家?
在HarmonyOS开发中,处理多层级手势事件是一项挑战,尤其在“组件套组件”的复杂布局下。本文深入探讨了触摸事件的基础原理、父子组件间的手势竞争规则以及如何通过`responseRegion`和`hitTestBehavior`等属性自定义触摸分发逻辑。同时介绍了`.gesture()`、`.priorityGesture()`和`.parallelGesture()`三种手势绑定方法,帮助开发者灵活调整手势优先级。掌握这些技巧,可精准控制复杂交互中的触摸行为,提升用户体验。
144 0
|
3月前
|
开发者
鸿蒙开发:资讯项目实战之项目初始化搭建
目前来说,我们的资讯项目只是往前迈了很小的一步,仅仅实现了项目创建,步虽小,但概念性的知识很多,这也是这个项目的初衷,让大家不仅仅可以掌握日常的技术开发,也能让大家理解实际的项目开发知识。
鸿蒙开发:资讯项目实战之项目初始化搭建
|
3月前
|
容器
HarmonyOS NEXT仓颉开发语言实战案例:外卖App
仓颉语言实战分享,教你如何用仓颉开发外卖App界面。内容包括页面布局、导航栏自定义、搜索框实现、列表模块构建等,附完整代码示例。轻松掌握Scroll、List等组件使用技巧,提升HarmonyOS应用开发能力。
|
3月前
|
缓存 JavaScript IDE
鸿蒙开发:基于最新API,如何实现组件化运行
手动只是让大家了解切换的原理,在实际开发中,可不推荐手动,下篇文章,我们将通过脚本或者插件,快速实现组件化模块之间的切换,实现独立运行,敬请期待!
118 0
鸿蒙开发:基于最新API,如何实现组件化运行
|
3月前
|
存储 IDE 定位技术
【HarmonyOS 5】鸿蒙组件&模板服务详解 - 助力高效开发的利器
在移动应用开发领域,效率与质量始终是开发者追求的核心目标。鸿蒙系统作为新兴的操作系统,为开发者提供了丰富且强大的开发资源,其中鸿蒙组件&模板服务更是成为开发者快速构建高质量应用的得力助手。
126 0