鸿蒙NEXT开发声明式UI是咋回事?
大家好,我是 V 哥,ArkTS 是 HarmonyOS 优选的主力应用开发语言,它在 TypeScript 的基础上进行了扩展,提供了声明式 UI 描述、自定义组件和动态扩展 UI 元素的能力。这些能力与 ArkUI 开发框架中的系统组件及其相关的事件方法、属性方法等共同构成了 UI 开发的主体。ArkTS 还提供了多维度的状态管理机制,允许数据在组件内使用,也可以在不同组件层级间传递,实现数据和 UI 的联动。此外,ArkTS 还提供了渲染控制的能力,包括条件渲染、循环渲染和数据懒加载,以适应不同的应用开发需求。

在声明式 UI 描述中,ArkTS 允许开发者以声明方式组合和扩展组件来描述应用程序的 UI。这包括基本的属性配置、事件处理和子组件的配置方法。例如,可以通过链式调用的方式配置系统组件的样式和其他属性,如 Text('hello').fontSize(20).fontColor(Color.Red)。同时,也可以设置组件的事件响应逻辑,如 Button('Click me').onClick(() => { this.myText = 'ArkUI'; })。此外,如果组件支持子组件配置,可以在闭包中添加子组件的 UI 描述,如 Column() { Text('Hello').fontSize(100) } 。
ArkTS 的声明式 UI 开发范式提供了一种高效、直观的方式来构建应用程序的用户界面。通过声明式语法,开发者可以更加专注于应用的逻辑和结构,而不是具体的实现细节,从而提高开发效率和代码的可维护性。随着 HarmonyOS 的不断发展,ArkTS 也将持续演进,提供更多的特性和能力,以满足开发者在应用开发和运行中的需求。

在HarmonyOS中,ArkTS语言提供了声明式UI的描述方式,允许开发者以声明的方式来构建和操作用户界面。以下是一些关键点和代码示例,以及对它们的分析:
1. 基本语法和组件创建
ArkTS定义了声明式UI描述、自定义组件和动态扩展UI元素的能力。在创建组件时,可以有无参数两种方式:
- 无参数组件:如果组件的接口定义没有包含必选构造参数,则组件后面的“()”不需要配置任何内容。例如,Divider组件不包含构造参数:
Column() {
Text('item 1')
Divider()
Text('item 2')
}
- 有参数组件:如果组件的接口定义包含构造参数,则在组件后面的“()”配置相应参数。例如,Image组件的必选参数src:
Image('https://weige/my.jpg')
或者Text组件的非必选参数content:
Text('weige')
2. 配置属性
属性方法以“.”链式调用的方式配置系统组件的样式和其他属性。例如,配置Text组件的字体大小:
Text('weige').fontSize(15)
也可以配置组件的多个属性:
Image('weige.jpg').alt('error.jpg').width(100).height(100)
3. 配置事件
事件方法以“.”链式调用的方式配置系统组件支持的事件。例如,使用lambda表达式配置组件的事件方法:
Button('Click me').onClick(() => {
this.myText = 'ArkUI';
})
4. 配置子组件
如果组件支持子组件配置,则需在尾随闭包"{…}"中为组件添加子组件的UI描述。例如,Column组件配置子组件的示例:
Column() {
Text('Hello').fontSize(100)
Divider()
Text(this.myText).fontSize(100).fontColor(Color.Red)
}
5. 状态管理
ArkTS提供了多维度的状态管理机制。状态变量变化会触发UI刷新。例如:
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
build() {
Column() {
Text('Hello').fontSize(30)
Text(this.message).fontSize(30)
Button() {
Text('Click Me').fontSize(30)
}.onClick(() => {
this.message='ArkUI'
}).width(200).height(50)
}
}
}
6. 渲染控制
ArkTS提供了渲染控制的能力,包括条件渲染、循环渲染和数据懒加载。这些能力允许开发者根据应用的不同状态,渲染对应状态下的UI内容。
通过这些基本语法和示例,开发者可以构建出功能丰富的HarmonyOS应用界面。ArkTS的声明式UI描述提供了一种高效、直观的方式来构建应用程序的用户界面。
鸿蒙NEXT开发声明式UI是咋回事?的更多相关文章
- 如何快速体验鸿蒙全新声明式UI框架ArkUI?
HDC2021将于10月22日在东莞松山湖正式开幕,大会将设立Codelab体验专区,超多好玩.有趣的Demo等你体验.想快速入门HarmonyOS?学习HarmonyOS新特性?以下几个Codela ...
- Mac最新Flutter环境搭建运行和对比理解声明式UI
前言 这段时间一直都在学习和写关于SwiftUI的东西,前面也总结了四篇文章来大体上说了下Demo中功能实现的一些细节,后面准备开始了解学习一下Flutter,争取在年前能再用Flutter写一份项目 ...
- 乘风破浪,遇见Android Jetpack之Compose声明式UI开发工具包,逐渐大一统的原生UI绘制体系
什么是Android Jetpack https://developer.android.com/jetpack Android Jetpack是一个由多个库组成的套件,可帮助开发者遵循最佳做法.减少 ...
- 客开监控(BE/UI/BP)插件停用与启用
1.单据界面右键属性,获取当前客开监控页面URL连接:http://172.16.168.15/U9/erp/display.aspx?lnk=UFSoft.UBF.Cust.CustManager& ...
- SpringCloud 源码系列(6)—— 声明式服务调用 Feign
SpringCloud 源码系列(1)-- 注册中心 Eureka(上) SpringCloud 源码系列(2)-- 注册中心 Eureka(中) SpringCloud 源码系列(3)-- 注册中心 ...
- Android全新UI编程 - Jetpack Compose 超详细教程
1. 简介 Jetpack Compose是在2019Google i/O大会上发布的新的库.Compose库是用响应式编程的方式对View进行构建,可以用更少更直观的代码,更强大的功能,能提高开发速 ...
- 转:对UI自动化测试的一些感悟
不断发掘自动化测试对各个团队的附加价值,这样才能得到来自四面八方的支持,没有将自动化加入项目过程的自动化都达不到预期的效果. UI自动化框架 把UI自动化框架设计成一个拼图性质的架构.把每个特性都设计 ...
- 关于Kendo UI 开发教程
Kendo UI 开发教程 jQuery UI 是一套 JavaScript 函式库,提供抽象化.可自订主题的 GUI 控制项与动画效果.基于 jQuery JavaScript 函式库,可用来建构互 ...
- 线程中更新ui方法汇总
一.为何写作此文 你是不是经常看到很多书籍中说:不能在子线程中操作ui,不然会报错.你是不是也遇到了如下的疑惑(见下面的代码): @Override protected void onCreate ...
- Android Kotlin Jetpack Compose UI框架 完全解析
前言 Q1的时候公司列了个培训计划,部分人作为讲师要上报培训课题.那时候刚从好几个Android项目里抽离出来,正好看到Jetpack发布了新玩意儿--Compose,我被它的快速实时打包给吸引住了, ...
随机推荐
- 实操教程 | 触发器实现 Apache DolphinScheduler 失败钉钉自动告警
作者 | sqlboy-yuzhenc 背景介绍 在实际应用中,我们经常需要将特定的任务通知给特定的人,虽然 Apache DolphinScheduler 在安全中心提供了告警组和告警实例,但是配置 ...
- 瑞芯微-I2S | 音频驱动调试基本命令和工具-基于rk3568-2
基于Linux嵌入式设备常用调试方法很多,本文一口君把调试语音用到的工具和方法给大家做一个简单的介绍. 1. procfs.sysfs Linux系统上的/proc目录是一种文件系统,即proc文件系 ...
- C#自定义结构体的(用SendMessage)传递
要传递结构体 public struct STUDENT { public int id; //ID public string name; //姓名 } 要引用Win32api函数FindWindo ...
- C# 读取DBF文件到Datatable
此种方式不依赖与任何驱动,第三方插件. 核心代码TDbfTable如下: using System; using System.Collections.Generic; using System.Te ...
- Visual Studio Code 配置文件关联
在编写 Linux 的 .service 文件的时候,我发现 .service 文件的本质是 INI 文件.然而 VS Code 却并没有使用 INI 格式进行语法高亮.于是我通过如下设置使 VS C ...
- 【测试平台开发】——02Vue前端框架实战—router路由设计(登录页面)
一.安装vue-cli Mac系统: sudo npm install -g vue-cli 检查是否安装好: vue -V 二.创建新项目 1.打开Vue项目管理器 输入命令: vue ui 但是没 ...
- C#自定义控件—流动管道
C#用户控件之流动管道 如何绘制一个动态的流动管道(FlowPipe)? 分两步绘制 定义属性: 画布重绘: 主要技能: 管道的绘制(渐变色矩形) /// <summary> /// 画渐 ...
- 【YashanDB知识库】yac修改参数后关闭数据库hang住
[标题]yac修改参数后关闭数据库hang住 [问题分类]性能优化 [关键词]YashanDB, yac, shutdown hang [问题描述]修改yac参数后执行shutdown immedia ...
- [Udemy] AWS Certified Data Analytics Specialty - 1.Collect
1. Connect Kinesis: 类似于Kafka, 分为 Data Streams(real time), Analytics, Firehose(near real time),区别是: o ...
- time series classification and transfer learning
最近在看几篇最近几年的工作和survey,希望早点能做点东西.