鸿蒙开发(九)UI实战 - 线性布局实现登录界面

前面我们花了很多章去讲述鸿蒙开发的UI,包括布局和控件等。本篇,我们综合使用布局和控件,完成一个简单的用户登录界面。

一、布局选择

简单回忆下我们掌握的几种布局,线性布局的控件横向或纵向线性排列,非常适合实现登录界面,因此我们使用线性布局来实现登录界面。

二、登录界面实现

1、创建UIAbility

创建LoginAbility,并且设置为Launcher ability:

可以看到,module.json5里面已经自动加上了skills:xxx.system.home,入口Ability只能有一个,记得把默认的EntryAbility的skills删掉:

2、创建页面

推荐使用New -Page的方式创建页面,这样会在main_pages自动添加页面名称,防止出现页面加载空白的case(我之前的demo就直接复制的Index,然后main_pages没增加页面信息,加载白屏。。。):

3、实现登录页面UI代码

如下代码实现了一个简单的登录界面,这是迄今为止写的最长的一个页面了,不过代码仍然比较简单,也比较好理解:

java 复制代码
import hilog from '@ohos.hilog';
import common from '@ohos.app.ability.common';

@Entry
@Component
struct Login {
  @State passport: string = '';
  @State password: string = '';
  private context = getContext(this) as common.UIAbilityContext

  build() {
    Column({ space: 5 }) {
      Row() {
        Text('账号:')
        TextInput({ placeholder: '请输入账号' })
          .width('60%')
          .height(40)
          .onChange((data: string) => {
            this.passport = data
          })
      }

      Row() {
        Text('密码:')
        TextInput({ placeholder: '请输入密码' })
          .width('60%')
          .height(40)
          .onChange((data: string) => {
            this.password = data
          })
      }

      Button('登录')
        .width('50%')
        .height(40)
        .margin({ top: 20 })
        .onClick(() => {
          this.doLogin()
        })
    }.width('100%').height('80%').justifyContent(FlexAlign.Center)
  }

  doLogin() {
    if (this.password || this.password == '') {
      hilog.info(0x0000, 'Login', 'password is null');
      return
    }
    if (this.passport || this.passport == '') {
      hilog.info(0x0000, 'Login', 'passport is null');
      return
    }
    hilog.info(0x0000, 'Login', 'passport:', '%{public}s', this.passport);
    hilog.info(0x0000, 'Login', 'password:', '%{public}s', this.password);
    // 触发login事件
    this.context.eventHub.emit('login')
  }
}

预览效果如下:

本篇,使用线性布局实现了一个简单的用户登录界面。后面,我还会结合各种各样的场景,去进行更多的UI实战。另外,在这里也提醒一下初学者,布局或控件的API没必要死记硬背,用到哪个布局或控件直接点进源码去看看,多看看源码也就记住了。

最后,分享一款免费看热门电影和电视剧的app,仅限Android:

相关推荐
中杯可乐多加冰11 小时前
Serverless 时代的内核革命——华为 openYuanrong 深度解析 异构多级缓存与 D2D 高速传输实测
缓存·华为·开源·serverless·openyuanrong
互联网散修11 小时前
零基础鸿蒙应用开发第四节:运算符与运算规则
华为·harmonyos
恋猫de小郭13 小时前
Flutter 鸿蒙 2026 路线发布,加速同步官方生态,进一步优化体验
前端·flutter·harmonyos
亚历克斯神14 小时前
Flutter 三方库 fft 的鸿蒙化适配指南 - 实现端侧高性能快速傅里叶变换、支持音频频谱分析与信号处理域的频域特征提取实战
flutter·harmonyos·鸿蒙·openharmony
爱学习的小齐哥哥14 小时前
鸿蒙常见问题分析三:视频关键帧提取与智能体图像分析
人工智能·pytorch·深度学习·harmonyos·harmony pc·harmonyos app
盐焗西兰花14 小时前
鸿蒙学习实战之路-Share Kit系列(11/17)-目标应用接收分享(分享详情页)
学习·华为·harmonyos
互联网散修14 小时前
零基础鸿蒙应用开发第二节:开发工具的功能介绍
华为·harmonyos
UnicornDev15 小时前
【HarmonyOS 6】个人中心数据可视化实战
华为·harmonyos·arkts·鸿蒙·鸿蒙系统
互联网散修15 小时前
鸿蒙应用开发UI基础第十八节:表单交互核心组件Button、Radio、Toggle示例演示
ui·交互·harmonyos
不要卷鸿蒙啊1 天前
【鸿蒙开发】HMRouter一款和好用的管理路由三方工具
前端·harmonyos