HarmonyOS 5.0 (Next)应用开发实战:使用ArkTS构建开箱即用的登录页面【HarmonyOS 5.0(Next)】

news/2024/12/22 22:47:01/文章来源:https://www.cnblogs.com/baoto/p/18622743

HarmonyOS 5.0 (Next)应用开发实战:使用ArkTS构建开箱即用的登录页面【HarmonyOS 5.0(Next)】

一、HarmonyOS 5.0美学与科技的完美融合

在科技飞速发展的今天,每一个细微的创新都可能引领一场变革。华为,作为科技领域的领航者,再次以HarmonyOS 5.0(Next)这一里程碑式的操作系统升级,向我们展示了科技的力量与魅力。它不仅是一次技术的飞跃,更是对未来智能生活的一次深刻洞察和重塑。

在这里插入图片描述

HarmonyOS 5.0(Next)首次引入了“光感美学”的设计理念,将光与影的巧妙结合融入系统界面。通过先进的算法和图像处理技术,系统界面呈现出更加细腻、生动的光影效果,为用户带来前所未有的视觉盛宴。这种设计不仅提升了系统的美观度,更在无形中增强了用户与设备之间的情感连接。

HarmonyOS 5.0(Next)在分布式软总线技术的基础上,进一步实现了多设备间的深度协同。无论是智能家居、智能穿戴还是智能办公设备,都能轻松接入鸿蒙生态,实现无缝流转和智能联动。用户只需轻轻一触,即可将手机上的视频、音乐、文档等内容快速分享到电视、平板或电脑上,真正实现了“一机在手,万物互联”的智能生活体验。
在这里插入图片描述

小艺助手,作为HarmonyOS 5.0(Next)的智能核心,得到了全面的升级和优化。它不仅能够准确理解用户的指令和需求,还能根据用户的习惯和偏好提供个性化的服务和建议。无论是日程管理、健康监测还是娱乐推荐,小艺助手都能轻松应对,让用户的生活更加便捷和高效。

在隐私安全方面,HarmonyOS 5.0(Next)采用了全新的安全架构和防护措施。系统深度整合了硬件级安全芯片和软件级安全防护机制,为用户的数据安全提供了全方位的保障。同时,系统还提供了丰富的隐私设置选项,让用户能够根据自己的需求灵活调整隐私权限,确保个人信息的安全和隐私。

1.1 项目背景

HarmonyOS(鸿蒙操作系统)是华为公司推出的一种分布式操作系统。它被设计为一种全场景、全连接的操作系统,旨在实现在各种设备之间的无缝协同和共享,包括智能手机、平板电脑、智能穿戴、智能家居、车载系统等。HarmonyOS的目标是构建一个统一的、开放的、全场景的操作系统生态系统。
这是我做项目中用到的应该展示页面。
在这里插入图片描述

1.2 ArkTS详解

ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript(简称TS)基本语法风格的基础上,对TS的动态类型特性施加更严格的约束,引入静态类型。同时,提供了声明式UI、状态管理等相应的能力,让开发者可以以更简洁、更自然的方式开发高性能应用。
自然简洁语法
ArkTS提供了简洁自然的声明式语法、组件化机制、数据-UI自动关联等能力,实现了贴近自然语言,书写效率更高的编程方式,为开发者带来易学、易懂、极简开发的优质体验。
轻量化并发机制
ArkCompiler运行时在HarmonyOS上提供了Worker API支持并发编程。在运行时实例内存隔离的基础上,ArkCompiler通过共享运行实例中的不可变或者不易变的对象、内建代码块、方法字节码等技术手段,优化了并发运行实例的启动性能和内存开销。

二.HarmonyOS应用开发实战—开箱即用的登录页面2【ArkTS】

在这里插入图片描述

2.1 ArkTS页面源码

import router from '@ohos.router';
import http from '@ohos.net.http';
import promptAction from '@ohos.promptAction'
@Entry
@Component
struct Index {@State activities: object[] = [{},{},];@State username: string = ''@State password: string = ''S_login() {if (this.username == "admin" && this.password == "admin") {router.replaceUrl({// url: "pages/one",url: "pages/one",params: {activities:this.activities}})}else {promptAction.showToast({message:"密码或用户名错误,请重新输入"})}}build() {Row() {Column({space:17}) {Image($r("app.media.logo")).width(80)Text("XXXXXArkts例示案例")TextInput({ placeholder: '输入用户名' }).width(300).height(60).fontSize(20).onChange((value: string) => {this.username = value})TextInput({ placeholder: '输入密码' }).width(300).height(60).fontSize(20).type(InputType.Password).onChange((value: string) => {this.password = value})Button('登录').width(300).height(60).fontSize(20).backgroundColor('#0F40F5').onClick(() => {this.S_login();})}.width('100%')}.height('100%')}
}

2.2 代码解析

这段代码是一个使用OHOS(OpenHarmony Operating System)开发的UI组件。它定义了一个名为Index的组件,该组件包含一个登录界面。

以下是对代码的详细分析:

  1. 首先,导入了三个模块:

    • router:用于页面跳转。
    • http:用于网络请求。
    • promptAction:用于显示提示信息,如Toast。
  2. Index组件定义了三个状态变量:

    • activities: 一个对象数组,初始为空。
    • username: 用户名字符串,初始为空。
    • password: 密码字符串,初始为空。
  3. S_login方法用于处理登录逻辑:

    • 如果用户名和密码都为"admin",则使用router.replaceUrl进行页面跳转,跳转到"pages/one",并将activities作为参数传递。
    • 否则,使用promptAction.showToast显示错误提示信息:"密码或用户名错误,请重新输入"。
  4. build方法定义了组件的构建结构:

    • 使用RowColumn布局组件创建一个垂直布局的行。
    • 在布局中添加以下元素:
      • 一个logo图片。
      • 文本"XXXXXArkts例示案例"。
      • 两个TextInput组件,分别用于输入用户名和密码。这两个组件的值变化会更新对应的usernamepassword状态变量。
      • 一个登录按钮。点击该按钮时,调用S_login方法进行登录处理。

整个组件就是一个简单的登录界面,用户可以输入用户名和密码进行登录,如果用户名和密码正确,则跳转到"pages/one"页面,否则显示错误提示信息。

2.3 心得

在分析和理解这段OHOS开发的UI组件代码过程中,以下是一些可能的心得体会:

  1. 模块化导入:代码中通过import语句导入了所需的模块,如routerhttppromptAction。这种模块化的设计有助于代码的组织和复用,使得代码结构更加清晰,同时也方便进行功能扩展。

  2. 状态管理:组件使用了@State装饰器来定义状态变量,如activitiesusernamepassword。这些状态变量在组件的生命周期中保持,并在状态变化时触发组件的重新渲染。这种方式有利于实现响应式编程,确保界面能够实时反映数据的变化。

  3. 方法封装:将登录逻辑封装在S_login方法中,实现了业务逻辑的分离。这种方法有助于提高代码的可读性和可维护性,使得代码更加模块化和易于测试。

  4. UI构建:使用布局组件(如RowColumn)和基础组件(如ImageTextTextInputButton)构建用户界面。这种声明式的UI构建方式使得界面设计更加直观和灵活,同时也能充分利用平台提供的优化和性能提升。

  5. 事件处理:在登录按钮上使用.onClick方法绑定点击事件,调用S_login方法进行登录处理。这种方式清晰地定义了用户交互与业务逻辑之间的关系,使得代码逻辑更加清晰。

  6. 用户体验:代码中考虑了用户体验的细节,如密码输入框使用.type(InputType.Password)设置为密码模式,保护用户隐私;错误提示信息使用promptAction.showToast显示,提供友好的反馈。

总的来说,这段代码展示了OHOS开发的一些最佳实践和特点,包括模块化、状态管理、方法封装、声明式UI构建和事件处理等。理解和掌握这些概念和技术,有助于编写出更加高效、可维护和具有良好用户体验的OHOS应用程序。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/856991.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

fellyfin 开启硬件加速 Ubuntu 安装硬件驱动

需要 root 权限。在主机系统上安装该intel-gpu-tools包,用于在 Linux 上调试英特尔显卡驱动程序。不同发行版的名称不同。在 Debian 和 Ubuntu 上:sudo apt update && sudo apt install -y intel-gpu-tools在 Jellyfin 网络客户端中播放视频,并通过设置较低的分辨率…

开箱即用的个人主页页面开发实战—基于HarmonyOS 5.0 (Next)和ArkTS的实现【HarmonyOS 5.0(Next)】

开箱即用的个人主页页面开发实战—基于HarmonyOS 5.0 (Next)和ArkTS的实现【HarmonyOS 5.0(Next)】 一、HarmonyOS 5.0(Next)革新设计理念,打造和谐美学 在科技日新月异的今天,操作系统作为智能设备的灵魂,正不断推动着数字生活的变革。华为,作为全球领先的科技企业,…

数据结构期末复习

武汉理工大学数据结构期末复习数据结构期末复习 By Persona_owl 第一章 绪论 1. 基本概念和术语数据:计算机操作的对象的总称,是信息的符号表示形式。数据元素: 数据的基本单位,通常作为一个整体进行处理,由更小的数据项组成。数据项是数据不可分割的最小单位。数据结构: 存…

探索HarmonyOS开发:用ArkTS构建个人主页和活动管理系统【HarmonyOS 5.0(Next)】

探索HarmonyOS开发:用ArkTS构建个人主页和活动管理系统【HarmonyOS 5.0(Next)】 一、一个系统,统一生态 口号:“一个系统,统一生态”,旨在全面突破操作系统核心技术,实现系统架构由内到外的焕然一新。 流畅度提升:相比前代,HarmonyOS 5.0(Next)的流畅度提升了30%,…

HarmonyOS应用开发实战-开箱即用的首页页面构建与ArkTS解析【HarmonyOS 5.0(Next)】

HarmonyOS应用开发实战-开箱即用的首页页面构建与ArkTS解析【HarmonyOS 5.0(Next)】 一、HarmonyOS Next 5.0的优势 AI能力:HarmonyOS Next 5.0通过系统级AI能力,将AI下沉至操作系统并赋能给多个子系统,从而提升了应用的智能化体验。例如,小艺助手在HarmonyOS Next 5.0中…

JavaWeb案例整体分析---》差旅费报销管理信息系统-数据库操作和Mybatis配置

数据库操作 ` CREATE TABLE ter_businessapply( id VARCHAR(8) PRIMARY KEY, name VARCHAR(50) NOT NULL, position VARCHAR(50) NOT NULL, department VARCHAR(50) NOT NULL, destination VARCHAR(100) NOT NULL, departure_date varchar(30) NOT NULL, return_date varchar(3…

深度科普文:细数倾斜摄影数据的缺点

详细介绍了倾斜摄影数据应用到三维可视化项目中的一些缺点。1. 引言 写这篇文章的起因是最近遇到一个使用倾斜摄影数据应标的三维可视化项目,业主认为倾斜摄影数据加载很卡,要求能浏览场景的时候能立刻显示出当前的场景最精细的模型,如下图1所示。其实这个问题遇到的次数还真…

Linux 性能调优命令

from pixivPS ps auxfps:显示系统中当前的进程信息。 a:显示与终端无关的所有进程(即显示所有用户的进程)。 u:以用户友好的格式显示进程信息,包括用户、CPU 和内存使用情况。 x:显示没有控制终端的进程,例如守护进程(daemon)。 f:以 ASCII 字符显示进程的树状结构,…

使用hackbar进行跨库注入

第一步 http://192.168.1.117/sqli-labs/Less-1/?id= union select 1,2,3 --+ //构建语句

Linux编写一个自己的命令

Linux编写一个自己的命令 编译一个.c文件,生成可执行文件out。out只有在当前目录下可以执行。 而命令可在任何路径执行想让out可以在任意路径执行,有以下两种办法 1、将执行文件添加到 /bin/ 路径下(专门存放可执行文件)添加到 /bin/ 路径下后,在任何路径都可识别到程序2、…

离开Jetbrains拥抱VsCode: 离开大便拥抱大便

文章讨论了作者从Jetbrains转向VsCode的原因,主要集中在AI编程支持和个性化体验上。Jetbrains在AI Coding的支持方面表现不佳,如更新速度慢、功能不足等,使得作者感到不满;而Jetbrains自己开发的AI Assistant也未能提供满意的体验。相对而言,VsCode在插件系统和自由度上表…

第十一篇:下载网站与动态网站架构

视频下载网站网站名:视频下载网站 域名:video.download.cn 站点目录:/app/code/vide/ 需求:浏览器打开后,显示目录结构 增加svip认证功能 增加统计功能(统计nginx服务的访问等状态)autoindex模块 自动索引功能(列表站点目录的内容),首页文件不存在autoindex模块 说明…