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

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

时间:2024-12-22 22:30:43浏览次数:4  
标签:5.0 activities val width height vp HarmonyOS 个人主页 offset

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

一、一个系统,统一生态

口号:“一个系统,统一生态”,旨在全面突破操作系统核心技术,实现系统架构由内到外的焕然一新。
流畅度提升:相比前代,HarmonyOS 5.0(Next)的流畅度提升了30%,系统运行更加丝滑。
续航增强:手机续航提升56分钟,有效提升了设备的续航时间。
全新设计:采用“和谐美学”设计,将光引入到鸿蒙设计中,通过算法模拟按钮光照效果,实现文字卡片与背景相互融合,令界面更加灵动惊艳。同时,新增了几套主题和锁屏实况窗,支持多功能卡片显示,使信息展示更加丰富和便捷。
分布式软总线:搭载全新分布式软总线,实现多设备之间无缝流传与共享,支持跨设备互通扫描、互通图库、跨设备剪贴板、应用内视频投播等功能。
小艺助手升级:搭载全新小艺助手,基于盘古大模型打造系统级AI,支持更多智能应用场景,如文档快速形成论文摘要、思维导图等。
安全性能提升:禁止应用获取9大不合理权限,所有应用均使用华为数据安全访问机制,采用星盾架构保护用户隐私。同时,支持文件加密分享,能够指定用户打开,且无法录屏、截图等。
方舟引擎升级:包括图形、多媒体、内存、调度、存储、低功耗、Web七大引擎都迎来提升,使得系统运行更加高效。
在这里插入图片描述

1.1 项目背景

HarmonyOS(鸿蒙操作系统)是华为公司推出的一种分布式操作系统。它被设计为一种全场景、全连接的操作系统,旨在实现在各种设备之间的无缝协同和共享,包括智能手机、平板电脑、智能穿戴、智能家居、车载系统等。HarmonyOS的目标是构建一个统一的、开放的、全场景的操作系统生态系统。

1.2 ArkTS详解

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

二.HarmonyOS应用开发实战—开箱即用的个人主页页面详情

在这里插入图片描述

2.1 ArkTS页面源码

import router from '@ohos.router';
import promptAction from '@ohos.promptAction';
import web_webview from '@ohos.web.webview';
@Entry
@Component
struct Page1 {
  @State message: string = 'Hello World'
  @State paramsFromIndex: object = router.getParams()
  @State activities: object[] = this.paramsFromIndex?.['activities']
  @State newActivity : object=
    {
      title: '',  // Assuming val is the title for the new activity
      type: "",    // Assign a type for the new activity
      description: "",
      time: "",
      where: '',
      flag:''
    }
  build() {

    Column() {
      Column() {
        Button("返回")
          .width("71.45vp")
          .height("47.01vp")
          .offset({ x: "-126.85vp", y: "-289.57vp" })
          .onClick(() => {
            router.replaceUrl({
              url: "pages/one",
              params: {
                activities:this.activities
              }
            })
          });
        Text("活动创建")
          .width("200vp")
          .height("60vp")
          .offset({ x: "73.54vp", y: "-341.74vp" })
          .fontSize("24fp")
          .margin({right:"10%"})
        Stack() {
          Text("时间:")
            .width("64.84vp")
            .height("39.78vp")
            .offset({ x: "-117.83vp", y: "-206.26vp" })
            .fontSize("18fp")
          Text("标题:")
            .width("64.84vp")
            .height("39.78vp")
            .offset({ x: "-116.66vp", y: "-257vp" })
            .fontSize("18fp")
          //标题
          TextInput()
            .onChange((val: string) => {
              this.newActivity['title']=val
            })
            .width("197.88vp")
            .height("37.65vp")
            .offset({ x: "18.58vp", y: "-256.73vp" })
          // 地点
          TextInput()
            .onChange((val: string) => {
              this.newActivity['where']=val
            })
            .width("197.88vp")
            .height("37.65vp")
            .offset({ x: "18.96vp", y: "-154.02vp" })
          // 活动描述
          TextInput()
            .onChange((val: string) => {
              this.newActivity['description']=val
            })
            .width("189.36vp")
            .height("37.65vp")
            .offset({ x: "19.1vp", y: "-103.98vp" })
          // 活动类型
          TextInput()
            .onChange((val: string) => {
              this.newActivity['type']=val
            })
            .width("189.36vp")
            .height("37.65vp")
            .offset({ x: "20.65vp", y: "-47.76vp" })

          // 照片
          TextInput()
            .width("351.09vp")
            .height("39.78vp")
            .offset({ x: "20.36vp", y: "68.43vp" })
          // 时间
          TextInput()
            .onChange((val: string) => {
              this.newActivity['time']=val
            })
            .width("200vp")
            .height("37.65vp")
            .offset({ x: "18.87vp", y: "-206.59vp" })
          Text("活动照片url:")
            .width("139.34vp")
            .height("41.91vp")
            .offset({ x: "-98.11vp", y: "4.09vp" })
            .fontSize("18fp")
          Text("活动类型:")
            .width("98.9vp")
            .height("39.78vp")
            .offset({ x: "-119vp", y: "-50.91vp" })
            .fontSize("18fp")
          Text("活动描述:")
            .width("98.9vp")
            .height("39.78vp")
            .offset({ x: "-123.28vp", y: "-101.03vp" })
            .fontSize("18fp")
          Text("地点:")
            .width("64.84vp")
            .height("39.78vp")
            .offset({ x: "-120.1vp", y: "-152.71vp" })
            .fontSize("18fp")
          Button("提交")
            .width("133.17vp")
            .height("52.33vp")
            .offset({ x: "0vp", y: "190.96vp" })
            .fontSize("19fp")
            .onClick(() => {
              console.log(String(this.newActivity['title']))
              console.log(String(this.activities))

              this.activities.push(this.newActivity);

              this.newActivity =
              {
                title: '',  // Assuming val is the title for the new activity
                type: "",    // Assign a type for the new activity
                description: "",
                time: "",
                where: ''
              }
              // this.flag1=
              router.replaceUrl({
                url: "pages/one",
                params: {
                  activities:this.activities
                }
              })
            })
        }
        .width("100%")
        .height("567.16vp")
        .offset({ x: "0vp", y: "-330.68vp" })
      }
      .width("100%")
      .height("100%")
      .offset({ x: "0vp", y: "285.38vp" })
      .justifyContent(FlexAlign.Center)
    }
    .width("100%")
    .height("100%")



  }
}

2.2 代码解析

这段代码看起来是用一种声明式语法编写的,用于定义用户界面(UI)组件。代码似乎创建了一个应用程序的UI页面,可能是为移动设备或Web环境设计的。

  1. 导入模块:

    • 代码使用import语句导入各种模块或库,如routerpromptActionweb_webview。这可能用于处理路由、用户提示和Web视图。
  2. 组件声明:

    • @Entry@Component很可能是装饰器或注解,用于声明以下结构(struct Page1)是一个组件。
  3. 状态管理:

    • @State装饰器用于定义状态。例如,message是一个字符串状态,paramsFromIndex是通过router.getParams()获取的参数,activities是从paramsFromIndex中提取的活动数组,newActivity是一个对象,表示新活动的各个属性。
  4. UI构建:

    • build方法定义了用户界面的结构。代码使用ColumnButtonText等组件来构建页面布局和元素。其中包括返回按钮、活动创建标题、文本输入框等。
  5. 事件处理:

    • 使用.onClick.onChange等方法来定义按钮和输入框等组件的交互行为。例如,当提交按钮被点击时,会将新活动添加到activities数组中,并重定向到另一个页面。

2.3 心得

通过对这段代码的解析,可以得到以下心得:

  1. 语言特性: 代码中使用了一种具有声明式语法的编程语言,它可能是为了构建用户界面而设计的。这种语法看起来更贴近描述界面的结构和交互,而非直接操作DOM或UI元素。

  2. 组件化: 通过@Componentstruct Page1,代码采用了组件化的设计思路。这种方式有助于将用户界面划分为可重用的独立部分,提高了代码的可维护性和可扩展性。

  3. 状态管理: 使用@State来定义组件的状态,例如messageparamsFromIndexactivities。这种状态管理的方式使得组件能够在不同的用户交互和事件中保持一致的状态。

  4. 事件处理: 通过.onClick.onChange等事件处理方法,代码实现了用户界面元素的交互行为。例如,在按钮点击时执行路由切换操作,在文本输入框变化时更新相应的活动属性。

  5. 路由和导航: 代码中引入了router模块,表明应用可能涉及页面之间的导航和路由。这是构建多页面应用或单页面应用时常见的功能。

  6. 布局和样式: 通过组合使用ColumnButtonText等组件,代码定义了页面的布局结构,并通过.width.height.offset等属性设置了各个组件的样式和位置。

  7. 异步和回调: 代码中可能涉及异步操作,例如在按钮点击时执行的路由操作,这可能是因为路由切换是一个可能耗时的操作。

总体而言,这段代码展示了一种以声明式方式构建用户界面的方法,采用了组件化的设计理念,同时处理了状态、事件和导航等方面的功能。这种风格的代码通常更易读、易于维护,并且有助于提高开发效率。

标签:5.0,activities,val,width,height,vp,HarmonyOS,个人主页,offset
From: https://www.cnblogs.com/baoto/p/18622708

相关文章

  • HarmonyOS应用开发实战-开箱即用的首页页面构建与ArkTS解析【HarmonyOS 5.0(Next)】
    HarmonyOS应用开发实战-开箱即用的首页页面构建与ArkTS解析【HarmonyOS5.0(Next)】一、HarmonyOSNext5.0的优势AI能力:HarmonyOSNext5.0通过系统级AI能力,将AI下沉至操作系统并赋能给多个子系统,从而提升了应用的智能化体验。例如,小艺助手在HarmonyOSNext5.0中得到了显著增强......
  • HarmonyOS应用开发实战:基于ArkTS的开箱即用登录页面实现【样式方式实现①】【HarmonyO
    HarmonyOS应用开发实战:基于ArkTS的开箱即用登录页面实现【样式方式实现①】【HarmonyOS5.0(Next)】一.HarmonyOSNext5.0发布时间:2024年10月22日,在华为全场景新品发布会上正式发布。地位:HarmonyOSNEXT成为全球继苹果iOS和安卓系统后的第三大移动操作系统,标志着华为在操作系统......
  • 基于HarmonyOS 5.0的元服务:技术架构、应用场景与未来发展【探讨】
    基于HarmonyOS5.0的元服务:技术架构、应用场景与未来发展【探讨】引言随着数字化技术的不断进步,智能设备的互联互通成为科技发展的主流方向。华为的HarmonyOS5.0系统在这一趋势下推出了创新性的“元服务”概念。元服务(SuperService)是鸿蒙系统中的一种新型服务架构,旨在为用户......
  • 基于HarmonyOS 5.0 (Next)技术的渐变模糊效果技术实现【代码实战】
    基于HarmonyOS5.0(Next)技术的渐变模糊效果技术实现【代码实战】HarmonyOS5.0(Next)作为华为自主研发的操作系统,以其强大的性能和丰富的开发功能吸引了众多开发者。本文将详细介绍如何在HarmonyOS5.0(Next)中实现渐变模糊效果,并通过代码实战展示具体操作步骤。ArkTS:HarmonyOS......
  • 基于HarmonyOS 5.0 (Next)的一种面向多设备跨平台的高性能自适应布局能力研究和实现
    引言随着万物互联时代的到来,操作系统作为连接设备、应用与用户体验的核心,其重要性日益凸显。华为最新发布的HarmonyOS5.0(Next)作为一款完全自主的第三大手机操作系统,不仅实现了全栈自研,更在技术架构和生态体验上实现了颠覆性升级。HarmonyOS5.0(Next)通过全新的技术框架和独特的Ar......
  • 鸿蒙HarmonyOS 5.0快速开发APP:一步一步教你从入门到进阶
    电信巨擘华为10月22日宣布推出“纯血”鸿蒙作业系统(操作系统)HarmonyOS5.0,引发全球智能装备市场高度关注。这套系统强调完全自主研发,是首个国产行动作业系统。这套系统已成为全球第三大行动作业系统,仅次于苹果iOS系统和谷歌旗下的安卓(Android)。华为宣布正式发布纯血鸿蒙作......
  • 鸿蒙HarmonyOS应用开发 | 「鸿蒙技术分享」HarmonyOS NEXT元服务卡片实战体验
    「鸿蒙技术分享」—HarmonyOSNEXT元服务卡片实战体验HarmonyOSNEXT是华为鸿蒙系统的最新版本,带来了更为流畅、高效的体验,并以元服务卡片(ServiceWidget)为核心,优化了服务分发和交互体验。本文将从开发者的角度,分享如何开发和部署元服务卡片,并结合代码实例,带你体验全新的卡片开......
  • HarmonyOS Next开发工具DevEco Studio介绍:ASan与TSan检测根治你的C++恐惧症
    1、背景介绍很多开发者面对C++都很犯怵,其中主要的一块就是内存操作。不合理的内存操作,比如数组越界、内存泄露、释放已释放的地址,可能会引起程序性能问题:内存消耗大,卡顿,更严重的会导致程序出现崩溃。当应用运行发生错误使应用进程终止时,应用将会抛出错误日志以通知应用崩溃......
  • 鸿蒙HarmonyOS应用开发 |鸿蒙技术分享HarmonyOS Next 深度解析:分布式能力与跨设备协作
    鸿蒙技术分享:HarmonyOSNext深度解析:分布式能力与跨设备协作实战随着万物互联时代的到来,操作系统作为连接设备、应用与用户体验的核心,扮演着不可或缺的角色。华为最新发布的HarmonyOSNext(鸿蒙操作系统下一代版本)不仅在技术架构上实现了颠覆性升级,更在生态体验上迈向了一个新的......
  • 鸿蒙HarmonyOS应用开发 | HarmonyOS Next-从应用开发到上架全流程解析
    HarmonyOSNext-从应用开发到上架全流程解析随着智能设备的不断普及,操作系统的竞争变得愈加激烈。在这个背景下,华为推出的HarmonyOS(鸿蒙操作系统)逐渐崭露头角,成为一个引人注目的新兴平台。本文将深入探讨HarmonyOSNext的应用开发流程,并特别关注鸿蒙应用上架的全过程,同时介绍鸿蒙......