13-鸿蒙开发中的综合实战:华为登录界面

news/2024/11/6 17:13:55 标签: harmonyos, 华为, 鸿蒙, 鸿蒙系统, 前端

      大家好,欢迎来到鸿蒙开发系列教程!今天,我们将通过一个综合实战项目来实现一个华为登录界面。这个项目将涵盖输入框组件、按钮组件、文本组件和布局容器的使用,帮助你更好地理解和应用这些组件。无论你是初学者还是有一定经验的开发者,这个实战项目都将对你有所帮助。让我们开始吧!

1. 项目目标

我们将创建一个简单的登录界面,包含以下功能:

  1. 用户名输入框
  2. 密码输入框
  3. 登录按钮
  4. 忘记密码链接
  5. 注册链接

2.技术栈

  • 框架鸿蒙开发框架(ArkUI)
  • 语言:TypeScript

3.项目结构

  1. 输入框组件TextField:用于接收用户的用户名和密码输入。
  2. 按钮组件Button:用于触发登录操作。
  3. 文本组件Text:用于显示提示信息和链接。
  4. 布局容器:使用 Column 和 Row 布局容器来组织界面元素。
步骤详解
  1. 创建项目

     

    首先,我们需要创建一个新的鸿蒙项目。你可以使用 DevEco Studio 创建一个新的 ArkUI 项目。

  2. 定义界面结构

     

    index.ets 文件中,定义登录界面的结构。

    import { Column, Row, Text, TextField, Button, Link, FlexAlign } from '@ohos/arkui';
    
    export default {
        data: {
            username: '',
            password: ''
        },
        build() {
            return (
                <Column width="100%" height="100%" alignItems="center" justifyContent="center">
                    <Text style={{ fontSize: '24px', marginBottom: '20px' }}>华为登录</Text>
                    <TextField
                        placeholder="请输入用户名"
                        type="text"
                        value={this.data.username}
                        style={{ width: '80%', marginBottom: '20px' }}
                        onChange={(event) => this.updateUsername(event.value)}
                    />
                    <TextField
                        placeholder="请输入密码"
                        type="password"
                        value={this.data.password}
                        style={{ width: '80%', marginBottom: '20px' }}
                        onChange={(event) => this.updatePassword(event.value)}
                    />
                    <Button
                        type="primary"
                        style={{ width: '80%', marginBottom: '20px' }}
                        onClick={() => this.handleLogin()}
                    >
                        登录
                    </Button>
                    <Row width="80%" justifyContent="space-between">
                        <Link href="#" style={{ color: '#007aff' }} onClick={() => this.handleForgotPassword()}>
                            忘记密码?
                        </Link>
                        <Link href="#" style={{ color: '#007aff' }} onClick={() => this.handleRegister()}>
                            注册
                        </Link>
                    </Row>
                </Column>
            );
        },
        updateUsername(username) {
            this.data.username = username;
        },
        updatePassword(password) {
            this.data.password = password;
        },
        handleLogin() {
            console.log('用户名:', this.data.username);
            console.log('密码:', this.data.password);
            alert('登录成功!');
        },
        handleForgotPassword() {
            alert('忘记密码功能暂未实现');
        },
        handleRegister() {
            alert('注册功能暂未实现');
        }
    };
详细解释
  1. 布局容器

    • Column:作为最外层的容器,使用 Column 布局容器将所有控件垂直排列。
    • Row:用于水平排列“忘记密码”和“注册”链接。
  2. 文本组件

    • Text:用于显示登录标题。
    • Link:用于显示“忘记密码”和“注册”链接。
  3. 输入框组件

    • TextField:用于接收用户的用户名和密码输入。通过 onChange 事件更新数据模型中的值。
  4. 按钮组件

    • Button:用于触发登录操作。通过 onClick 事件处理登录逻辑。
  5. 数据模型

    • data:包含用户名和密码的初始值。
    • updateUsername 和 updatePassword:用于更新数据模型中的用户名和密码。
    • handleLogin:处理登录逻辑,打印用户名和密码,并显示登录成功的提示。
    • handleForgotPassword 和 handleRegister:处理忘记密码和注册链接的点击事件,目前只是显示提示信息。
样式说明
  • fontSize:设置文本的字体大小。
  • marginBottom:设置控件的下边距。
  • width:设置控件的宽度。
  • color:设置链接的颜色。
运行项目
  1. 打开 DevEco Studio。
  2. 选择你的项目并点击运行按钮。
  3. 在模拟器或真机上查看登录界面的效果。
总结

通过本文,你已经学会了如何在鸿蒙开发中实现一个简单的登录界面,涵盖了输入框组件、按钮组件、文本组件和布局容器的使用。这个实战项目不仅帮助你巩固了基础知识,还提供了一个实际的应用场景。希望这篇文章对你有所帮助,如果有任何问题或建议,欢迎在评论区留言交流。期待在鸿蒙开发的道路上与你共同成长!


希望这篇文章对你有所帮助,如果有任何问题或建议,欢迎随时留言交流!再见!


http://www.niftyadmin.cn/n/5741085.html

相关文章

linux shell脚本学习(1):shell脚本基本概念与操作

1.什么是shell脚本 linux系统中&#xff0c;shell脚本或称之为bash shell程序&#xff0c;通常是由vim编辑&#xff0c;由linux命令、bash shell指令、逻辑控制语句、注释信息组成的可执行文件 *linux中常以.sh后缀作为shell脚本的后缀。linux系统中文件乃至脚本的后缀并没有…

猎板PCB2到10层数的科技进阶与应用解析

1. 单层板&#xff08;Single-sided PCB&#xff09; 定义&#xff1a;单层板是最基本的PCB类型&#xff0c;导线只出现在其中一面&#xff0c;因此被称为单面板。限制&#xff1a;由于只有一面可以布线&#xff0c;设计线路上有许多限制&#xff0c;不适合复杂电路。应用&…

科技改变阅读习惯:最新研究揭示电子阅读器的普及趋势

据QYResearch调研团队最新报告“全球电子阅读器市场报告2023-2029”显示&#xff0c;预计2029年全球电子阅读器市场规模将达到6.9亿美元&#xff0c;未来几年年复合增长率CAGR为0.4%。 如上图表/数据&#xff0c;摘自QYResearch最新报告“全球电子阅读器市场研究报告2023-2029.…

蓝桥杯 Python组-神奇闹钟(datetime库)

神奇闹钟 传送门&#xff1a; 0神奇闹钟 - 蓝桥云课​​​​​​ 问题描述 小蓝发现了一个神奇的闹钟&#xff0c;从纪元时间&#xff08;1970 年 11 日 00&#xff1a;00&#xff1a;00&#xff09;开始&#xff0c;每经过 x 分钟&#xff0c;这个闹钟便会触发一次闹铃 (…

C#笔记(3)

好的OOP程序--->模块合理、结构清晰、程序规范、注释明确、运行流畅、维护容易、扩展方法。 OOP是学习各种编程的原则、方法、技巧、经验、模式、架构等。 所有面向对象的编程语言&#xff0c;都是把我们要处理的”数据“和”行为“封装到类中。 1、设计类 2、关联类 3…

MinerU容器构建教程

一、介绍 MinerU作为一款智能数据提取工具&#xff0c;其核心功能之一是处理PDF文档和网页内容&#xff0c;将其中的文本、图像、表格、公式等信息提取出来&#xff0c;并转换为易于阅读和编辑的格式&#xff08;如Markdown&#xff09;。在这个过程中&#xff0c;MinerU需要利…

使用 Spring Boot 集成 Thymeleaf 和 Flying Saucer 实现 PDF 导出

在 Spring Boot 项目中&#xff0c;生成 PDF 报表或发票是常见需求。本文将介绍如何使用 Spring Boot 集成 Thymeleaf 模板引擎和 Flying Saucer 实现 PDF 导出&#xff0c;并提供详细的代码实现和常见问题解决方案。 目录 一、项目依赖二、创建 Thymeleaf 模板三、创建 PDF 生…

蓝桥杯真题——乐乐的序列和(C语言)

问题描述 乐乐在玩一个游戏&#xff0c;她有一排宝石&#xff0c;每个宝石上都刻有一个整数值。她的目标是从中挑选出一些宝石&#xff0c;使得选出的宝石数量为偶数&#xff0c;且这些宝石上的数字总和最大。如果不选任何宝石&#xff08;即选出宝石数量为 00&#xff0c;也是…