第五天 初步了解ArkTS和ArkUI
初步了解ArkTS和ArkUI,可以从以下几个方面进行概述:
一、ArkTS简介
-
定义与关系:
- ArkTS是HarmonyOS(鸿蒙系统)优选的主力应用开发语言。
- 它基于TypeScript(TS)进行扩展,兼容TS的所有特性,并增加了声明式UI、状态管理等能力,是TS的超集。
-
核心特性:
- 声明式UI:ArkTS通过声明式的方式描述UI结构,使开发者能够更简洁、更自然地开发跨端应用。
- 状态管理:提供了多维度的状态管理机制,支持在组件内、组件间以及全局范围内传递和更新状态。
- 渲染控制:包括条件渲染、循环渲染和数据懒加载等能力,根据应用状态或数据源动态地渲染UI内容。
-
开发范式:
- ArkTS主要采用声明式开发范式,这种范式更接近自然语义的编程方式,有助于提高开发效率和应用性能。
二、ArkUI简介
-
定义与功能:
- ArkUI是HarmonyOS应用的UI开发框架,提供了完整的UI开发基础设施。
- 它包括简洁的UI语法、丰富的UI功能(如组件、布局、动画以及交互事件)以及实时界面预览工具等。
-
组件与布局:
- 组件:UI构建与显示的最小单位,ArkUI内置了丰富的多态组件,如Image、Text、Button等,并支持用户自定义组件。
- 布局:ArkUI提供了多种布局方式,包括弹性布局、列表布局、宫格布局、栅格布局和原子布局等,以满足不同分辨率和设备的适配需求。
-
动画与交互:
- 动画:ArkUI支持属性动画、转场动画和自定义动画能力,为UI界面增添动态效果。
- 交互事件:提供了多种交互能力,默认适配触摸手势、遥控器按键输入、键鼠输入等,并提供了相应的事件回调以便开发者添加交互逻辑。
-
开发范式:
- ArkUI针对不同的应用场景和技术背景的开发者提供了两种开发范式:
- 声明式开发范式:基于ArkTS语言,更适合构建复杂和动态的UI界面。
- 类Web开发范式:采用经典的HML、CSS、JavaScript三段式开发方式,更符合Web前端开发者的使用习惯。
- ArkUI针对不同的应用场景和技术背景的开发者提供了两种开发范式:
综上所述,ArkTS和ArkUI共同构成了HarmonyOS应用开发的强大工具链。ArkTS作为应用开发语言,提供了声明式UI描述、状态管理和渲染控制等核心特性;而ArkUI作为UI开发框架,则提供了丰富的组件、布局、动画和交互事件等功能。两者相辅相成,共同助力开发者高效、简洁地开发跨端应用。
示例:简单的Hello World应用
1. 使用ArkTS进行声明式开发
首先,我们创建一个ArkTS文件(例如App.arkts),这个文件将包含我们的应用逻辑和UI描述。
// App.arkts
import { Component, defineComponent } from '@arkui/core';@Component
struct HelloWorld {@State message: string = 'Hello, World!';build() {Column() {Text(this.message).fontSize(24).fontWeight('bold').textAlign('center').margin({ top: '20vp' });}.backgroundColor('#FFFFFF').justifyContent('center').alignItems('center').height('100vh');}
}export default defineComponent(HelloWorld);
在这个示例中,我们定义了一个名为HelloWorld的组件。它包含一个状态message,初始值为'Hello, World!'。在build方法中,我们使用Column布局容器和Text组件来显示这个消息。Column容器设置了背景颜色、居中对齐和占满视口高度的样式。
2. 配置入口文件(可选)
在某些情况下,你可能需要配置一个入口文件来指定你的应用从哪个组件开始渲染。在HarmonyOS中,这通常是通过一个配置文件来完成的(例如index.json或config.json),但在这里我们假设DevEco Studio已经为你处理了这些配置,并且App.arkts是我们的入口组件。
3. 运行应用
在DevEco Studio中,你可以直接运行这个应用。它将启动一个模拟器或连接到真实设备,并在屏幕上显示“Hello, World!”消息。
注意事项
- 这个示例代码是基于概念性的,实际的ArkTS和ArkUI API可能会有所不同。
- 在真实的开发环境中,你需要确保已经正确安装了DevEco Studio和HarmonyOS SDK。
- 你可能还需要配置一些额外的项目设置,如依赖项、签名证书等。
- 由于ArkTS是TypeScript的超集,它兼容TypeScript的所有语法和特性,因此你可以使用TypeScript的所有高级功能来编写你的应用。
类Web开发范式示例(可选)
如果你更喜欢使用类Web的开发范式,你可以使用HML(Harmony Markup Language)、CSS和JavaScript来构建你的应用。以下是一个简单的示例:
<!-- index.hml -->
<div class="container"><text class="message">{{message}}</text>
</div>
/* index.css */
.container {display: flex;justify-content: center;align-items: center;height: 100vh;background-color: #FFFFFF;
}.message {font-size: 24px;font-weight: bold;text-align: center;margin-top: 20vp;
}
// index.js
export default {data: {message: 'Hello, World!'}
}
在这个类Web开发范式的示例中,我们使用了HML来描述UI结构,CSS来设置样式,JavaScript来管理数据。然而,请注意,在HarmonyOS的实际开发中,你可能需要使用特定的框架或库(如ArkUI的类Web部分)来支持这种开发方式,并且API可能会有所不同。此外,随着HarmonyOS的发展,推荐的开发范式可能会发生变化,因此建议查阅最新的官方文档来获取最准确的信息。
相关文章:
第五天 初步了解ArkTS和ArkUI
初步了解ArkTS和ArkUI,可以从以下几个方面进行概述: 一、ArkTS简介 定义与关系: ArkTS是HarmonyOS(鸿蒙系统)优选的主力应用开发语言。它基于TypeScript(TS)进行扩展,兼容TS的所有特…...
java中的锁面试题
1、多线程中 synchronized 锁升级的原理是什么? synchronized 是JVM层面的锁,是 Java 关键字,通过 monitor 对象来完成,synchronized 的实现涉及到锁的升级,具体为无锁、偏向锁、自旋锁、重量级锁 synchronized 锁升级…...
ES6 变量解构赋值总结
1. 数组的解构赋值 1.1 基本用法 // 基本数组解构 const [a, b, c] [1, 2, 3]; console.log(a); // 1 console.log(b); // 2 console.log(c); // 3// 跳过某些值 const [x, , y] [1, 2, 3]; console.log(x); // 1 console.log(y); // 3// 解构剩余元素 const [first, ...re…...
知识蒸馏教程 Knowledge Distillation Tutorial
来自于:Knowledge Distillation Tutorial 将大模型蒸馏为小模型,可以节省计算资源,加快推理过程,更高效的运行。 使用CIFAR-10数据集 import torch import torch.nn as nn import torch.optim as optim import torchvision.tran…...
DeepSeek各版本说明与优缺点分析
DeepSeek各版本说明与优缺点分析 DeepSeek是最近人工智能领域备受瞩目的一个语言模型系列,其在不同版本的发布过程中,逐步加强了对多种任务的处理能力。本文将详细介绍DeepSeek的各版本,从版本的发布时间、特点、优势以及不足之处࿰…...
java进阶专栏的学习指南
学习指南 java类和对象java内部类和常用类javaIO流 java类和对象 类和对象 java内部类和常用类 java内部类精讲Object类包装类的认识String类、BigDecimal类初探Date类、Calendar类、SimpleDateFormat类的认识java Random类、File类、System类初识 javaIO流 java IO流【…...
kamailio-osp模块
该文档详细讲解了如何在Kamailio中配置和使用OSP模块(Open Settlement Protocol Module),以实现基于ETSI标准的安全多边对等互联(Secure Multi-Lateral Peering)。以下是核心内容的总结: 1. 模块功能 OSP模…...
【TensorFlow】T1:实现mnist手写数字识别
🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 1、设置GPU import tensorflow as tf gpus tf.config.list_physical_devices("GPU")if gpus:gpu0 gpus[0]tf.config.experimental.set_memory_g…...
Rapidjson 实战
Rapidjson 是一款 C 的 json 库. 支持处理 json 格式的文档. 其设计风格是头文件库, 包含头文件即可使用, 小巧轻便并且性能强悍. 本文结合样例来介绍 Rapidjson 一些常见的用法. 环境要求 有如何的几种方法可以将 Rapidjson 集成到您的项目中. Vcpkg安装: 使用 vcpkg instal…...
【React】受控组件和非受控组件
目录 受控组件非受控组件基于ref获取DOM元素1、在标签中使用2、在组件中使用 受控组件 表单元素的状态(值)由 React 组件的 state 完全控制。组件的 state 保存了表单元素的值,并且每次用户输入时,React 通过事件处理程序来更新 …...
Ollama+deepseek+Docker+Open WebUI实现与AI聊天
1、下载并安装Ollama 官方网址:Ollama 安装好后,在命令行输入, ollama --version 返回以下信息,则表明安装成功, 2、 下载AI大模型 这里以deepseek-r1:1.5b模型为例, 在命令行中,执行&…...
DEEPSEKK GPT等AI体的出现如何重构工厂数字化架构:从设备控制到ERP MES系统的全面优化
随着深度学习(DeepSeek)、GPT等先进AI技术的出现,工厂的数字化架构正在经历前所未有的变革。AI的强大处理能力、预测能力和自动化决策支持,将大幅度提升生产效率、设备管理、资源调度以及产品质量管理。本文将探讨AI体(…...
阿莱(arri)mxf文件变0字节的恢复方法
阿莱(arri)是专业级的影视产品软硬件供应商,很多影视作品都是使用阿莱(arri)的设备拍摄出来的。总体上来讲阿莱(arri)的文件格式有mov和mxf两种,这次恢复的是阿莱(arri)的mxf,机型是arri mini,素材保存在一个8t的硬盘上,使用的是e…...
初识 Node.js
在当今快速发展的互联网技术领域,Node.js 已经成为了一个非常流行且强大的平台。无论是构建高性能的网络应用、实时协作工具还是微服务架构,Node.js 都展示了其独特的优势。本文将带您走进 Node.js 的世界,了解它的基本概念、核心特性以及如何…...
debug-vscode调试方法
debug - vscode gdb调试指南 文章目录 debug - vscode gdb调试指南前言一、调试代码二、命令查看main反汇编查看寄存器打印某个变量打印寄存器,如pc打印当前函数栈信息(当前执行位置)打印程序栈局部变量x命令的语法如下所示:打印某…...
Cypher进阶(函数、索引)
文章目录 Cypher进阶Aggregationcount()函数统计函数collect()函数 unwindforeachmergeunionload csvcall 函数断言函数all()any()~~exists()~~is not nullnone()single() 标量函数coalesce()startNode()/endNode()id()length()size() 列表函数nodes()keys()range()reduce() 数…...
XML Schema 数值数据类型
XML Schema 数值数据类型 引言 XML Schema 是一种用于描述 XML 文档结构的语言。它定义了 XML 文档中数据的有效性和结构。在 XML Schema 中,数值数据类型是非常重要的一部分,它定义了 XML 文档中可以包含的数值类型。本文将详细介绍 XML Schema 中常用的数值数据类型,以及…...
Window获取界面空闲时间
GetLastInputInfo是一种Windows API函数,用于获取上次输入操作的时间。 该函数通过LASTINPUTINFO结构返回最后一次输入事件的时间。 原型如下 BOOL WINAPI GetLastInputInfo(PLASTINPUTINFO plii);那么可以利用GetLastInputInfo来得到界面没有操作的时长 uint…...
Java进阶(vue基础)
目录 1.vue简单入门 ?1.1.创建一个vue程序 1.2.使用Component模板(组件) 1.3.引入AXOIS ?1.4.vue的Methods(方法) 和?compoted(计算) 1.5.插槽slot 1.6.创建自定义事件? 2.Vue脚手架安装? 3.Element-UI的…...
Mac电脑上好用的压缩软件
在Mac电脑上,有许多优秀的压缩软件可供选择,这些软件不仅支持多种压缩格式,还提供了便捷的操作体验和强大的功能。以下是几款被广泛推荐的压缩软件: BetterZip 功能特点:BetterZip 是一款功能强大的压缩和解压缩工具&a…...
业务系统对接大模型的基础方案:架构设计与关键步骤
业务系统对接大模型:架构设计与关键步骤 在当今数字化转型的浪潮中,大语言模型(LLM)已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中,不仅可以优化用户体验,还能为业务决策提供…...
C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...
Java如何权衡是使用无序的数组还是有序的数组
在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...
Day131 | 灵神 | 回溯算法 | 子集型 子集
Day131 | 灵神 | 回溯算法 | 子集型 子集 78.子集 78. 子集 - 力扣(LeetCode) 思路: 笔者写过很多次这道题了,不想写题解了,大家看灵神讲解吧 回溯算法套路①子集型回溯【基础算法精讲 14】_哔哩哔哩_bilibili 完…...
Golang dig框架与GraphQL的完美结合
将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用,可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器,能够帮助开发者更好地管理复杂的依赖关系,而 GraphQL 则是一种用于 API 的查询语言,能够提…...
【快手拥抱开源】通过快手团队开源的 KwaiCoder-AutoThink-preview 解锁大语言模型的潜力
引言: 在人工智能快速发展的浪潮中,快手Kwaipilot团队推出的 KwaiCoder-AutoThink-preview 具有里程碑意义——这是首个公开的AutoThink大语言模型(LLM)。该模型代表着该领域的重大突破,通过独特方式融合思考与非思考…...
《通信之道——从微积分到 5G》读书总结
第1章 绪 论 1.1 这是一本什么样的书 通信技术,说到底就是数学。 那些最基础、最本质的部分。 1.2 什么是通信 通信 发送方 接收方 承载信息的信号 解调出其中承载的信息 信息在发送方那里被加工成信号(调制) 把信息从信号中抽取出来&am…...
Cinnamon修改面板小工具图标
Cinnamon开始菜单-CSDN博客 设置模块都是做好的,比GNOME简单得多! 在 applet.js 里增加 const Settings imports.ui.settings;this.settings new Settings.AppletSettings(this, HTYMenusonichy, instance_id); this.settings.bind(menu-icon, menu…...
论文浅尝 | 基于判别指令微调生成式大语言模型的知识图谱补全方法(ISWC2024)
笔记整理:刘治强,浙江大学硕士生,研究方向为知识图谱表示学习,大语言模型 论文链接:http://arxiv.org/abs/2407.16127 发表会议:ISWC 2024 1. 动机 传统的知识图谱补全(KGC)模型通过…...
LLM基础1_语言模型如何处理文本
基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…...
