DevEco Studio:状态管理与事件处理
DevEco Studio:状态管理与事件处理
引言
在现代前端开发中,状态管理和事件处理是构建交互式应用的核心。DevEco Studio,作为华为推出的开发环境,支持开发者使用TypeScript构建HarmonyOS应用。本文将通过三个示例代码,深入探讨如何在DevEco Studio中管理状态和处理事件。
第一节:状态变量与界面刷新
1.1 状态变量的重要性
在DevEco Studio中,状态变量(使用[@State](https://my.oschina.net/states) 装饰器修饰的变量)的变化会自动触发界面的刷新。这与普通变量不同,普通变量的变化不会引起界面的更新。
示例代码一
@Entry
@Component
struct Index {
@State message: string = 'Hello World';
build() {
Row() {
Column() {
Button('这是一个对话框')
.onClick(() => {
console.log('log:', '对话框')
AlertDialog.show({
message: '这是一个对话框框'
})
})
Text('这是一个文本')
.onClick(() => {
console.log('log:', '文本')
AlertDialog.show({
message: '这是一个文本组件'
})
})
}
.width('100%')
}
.height('100%')
}
}
运行结果
点击事件运行结果
1.2 普通变量与状态变量的区别
- 普通变量:只能在初始化时渲染,后续变化了,也不会引起更新。
- 状态变量:被装饰器修饰,值的改变会[自动]引起界面的刷新。
示例代码二
let myname: string = 'thewang'
@Entry
@Component
struct Index {
myage: number = 19
@State mymsg: string = 'hello thewang'
build() {
Column() {
Text(myname).onClick(() => {
myname = 'thetwo'
console.log('myname', myname)
})
Text(this.myage.toString()).onClick(() => {
this.myage = 18
console.log('age', this.myage)
})
Text(this.mymsg).onClick(() => {
this.mymsg = 'hello'
})
}
}
}
运行结果
HarmonyOS Next点击事件2
第二节:事件处理与界面更新
2.1 事件处理基础
在DevEco Studio中,事件处理是通过.onClick()方法实现的,它允许我们在用户交互时执行特定的函数。
示例代码三
计数器案例
@Entry
@Component
struct Index {
@State count: number = 1
build() {
Row() {
Button('-')
.onClick(() => {
this.count = this.count - 1
})
Text(this.count.toString()).margin(10)
Button('+')
.onClick(() => {
this.count = this.count + 1
})
}
.padding(20)
}
}
运行结果
HarmonyOS Next计数器案例
2.2 状态变量与界面更新
在上述代码中,count是一个状态变量。当按钮被点击时,count的值会改变,这会自动触发界面的更新,显示最新的计数。
2.3 界面布局与样式
- Row 和 Column:用于创建行和列的布局。
- Text 和 Button:用于显示文本和按钮。
- margin 和 padding:用于设置组件的边距。
第三节:算术运算符的使用
3.1 基本算术运算符
在TypeScript中,基本的算术运算符包括加(+)、减(-)、乘(*)、除(/)和取余(%)。
示例代码
console.log('result', 1 + 1);
console.log('result', 2 - 1);
console.log('result', 2 * 3);
console.log('result', 6 / 3);
console.log('remainder', 7 % 2); // 3余1
3.2 赋值运算符
赋值运算符允许我们将一个值赋给变量,或者对变量进行计算后重新赋值。
示例代码
let num2: number = 77;
num2 %= 10;
console.log('num2', num2);
运行结果
第四节:组件布局的构建
4.1 组件布局基础
在DevEco Studio中,我们可以使用Column和Row组件来构建布局。
示例代码二
@Entry
@Component
struct Index {
build() {
Column() {
// 外层Column,设置间距为8
Column({
space: 8 }) {
// 用颜色填充代替图片,使用Stack组件
Stack()
.width('100%')
.height(200) // 设置高度,根据实际情况调整
.backgroundColor('gray') // 设置背景颜色,这里用灰色示例
.borderRadius({
topLeft: 6, topRight: 6 }) // 设置圆角
// 标题文字
Text('这是标题,颜色填充部分可以换成图片')
.fontSize(14)
.lineHeight(18)
.padding({
left: 5, right: 5 })
// 来源和点赞
Row() {
// 来源
Row() {
Stack()
.width(16)
.height(16) // 设置高度,根据实际情况调整
.backgroundColor('blue') // 设置背景颜色,这里用蓝色示例
.margin({
right: 3 })
Text('用户名称')
.fontSize(12)
.fontColor('#7e7e7e')
}
// 点赞
Row() {
Stack()
.width(14)
.height(14) // 设置高度,根据实际情况调整
.backgroundColor('red') // 设置背景颜色,这里用红色示例
.margin({
right: 3 })
Text('8888')
.fontSize(12)
.fontColor('#7e7e7e')
}
}
.width('100%')
.justifyContent(FlexAlign.SpaceBetween)
.padding({
left: 5, right: 5 })
}
.width('50%')
}
.padding(20)
}
}
运行结果
结语
通过本文,我们学习了在DevEco Studio中管理状态和处理事件的基础知识。这些知识对于构建交互式应用至关重要。希望本文能够帮助你更好地理解和应用DevEco Studio进行开发。
注意:文章中提到的代码示例需要在DevEco Studio环境中运行,确保你已经配置好了相应的开发环境。如果你在运行示例时遇到任何问题,可以参考DevEco Studio的官方文档或寻求社区的帮助。
DevEco Studio:状态管理与事件处理的更多相关文章
- 查收新年礼物丨DevEco Studio 3.0 Beta2发布,20个新变化详解
HUAWEI DevEco Studio是开发HarmonyOS应用和原子化服务的一站式集成开发环境(IDE),为开发者提供工程模板创建.开发.编译.调试.发布等功能. 2021年12月31日,新版本 ...
- ASP.NET状态管理详解,让你明明白白
开发WinFrom的程序员可能不会在意维护应用程序的状态,因为WinFrom本身就在客户端运行,可以直接在内存中维护其应用程序状态.但ASP.NET应用程序在服务器端运行,客户端使用无状态的http协 ...
- vuex状态管理
msvue组件间通信时,若需要改变多组件间共用状态的值.通过简单的组件间传值就会遇到问题.如:子组件只能接收但改变不了父组件的值.由此,vuex的出现就是用作各组件间的状态管理. 简单实例:vuex的 ...
- 大数据计算引擎之Flink Flink状态管理和容错
这里将介绍Flink对有状态计算的支持,其中包括状态计算和无状态计算的区别,以及在Flink中支持的不同状态类型,分别有 Keyed State 和 Operator State .另外针对状态数据的 ...
- Redux状态管理方法与实例
状态管理是目前构建单页应用中不可或缺的一环,也是值得花时间学习的知识点.React官方推荐我们使用Redux来管理我们的React应用,同时也提供了Redux的文档来供我们学习,中文版地址为http: ...
- 表格搞定 Asp.net Web 状态管理
最近在网上搜罗了 ASP.NET WEB 状态管理方面的一些内容,终于把这些内容整合总结了一下. 1. 希望自己通过整理,能够掌握一些,为自己投资. 2. 以便自己忘记,又要浪费时间搜罗. 3. 希望 ...
- [译]面向初学者的Asp.Net状态管理技术
介绍 本文主要讲解Asp.Net应用程序中的状态管理技术(Asp.Net中有多种状态管理技术),并批判性地分析所有状态管理技术的优缺点. 背景 HTTP是无状态的协议.客户端发起一个请求,服务器响应完 ...
- [Asp.Net]状态管理(Session、Application、Cache)
上篇博文介绍了在客户端状态管理的两种方式:http://www.cnblogs.com/wolf-sun/p/3329773.html.除了在客户端上保存状态外,还可以在服务器上保存状态.使用客户端的 ...
- [Asp.Net]状态管理(ViewState、Cookie)
简介 HTTP协议是无状态的.从客户端到服务器的连接可以在每个请求之后关闭.但是一般需要把一些客户端信息从一个页面传送给另一个页面. 无状态的根本原因是:浏览器和服务器使用Socket通信,服务器将请 ...
- HttpClient_HttpClient 4.3.6 HTTP状态管理
HTTP状态管理 最初的HTTP被设计成以状态.请求/应答为导向的协议,它被制作成是没有特殊条款的,以便在状态会话中能交换逻辑关系请求/应答.HTTP协议越来越受欢迎和被采用,越来越多的系统会在应用程 ...
随机推荐
- Qt 中实现异步散列器
[写在前面] 在很多工作中,我们需要计算数据或者文件的散列值,例如登录或下载文件. 而在 Qt 中,负责这项工作的类为 QCryptographicHash. 关于 QCryptographicHas ...
- 深度DFS 和 广度BFS搜索算法学习
目录 广度优先的动态图 深度优先的动态图 广度和深度的具体步骤 深度和广度的应用场景 图的两种遍历方式: 深度优先遍历(DFS--Depth First Search) 广度优先遍历(BFS--Bre ...
- .NET 开源高性能 MQTT 类库
前言 随着物联网(IoT)技术的迅猛发展,MQTT(消息队列遥测传输)协议凭借其轻量级和高效性,已成为众多物联网应用的首选通信标准. MQTTnet 作为一个高性能的 .NET 开源库,为 .NET ...
- Windows系统环境变量
添加环境变量: 添加系统变量,机器要重新启动 添加用户变量,机器不用重启: 一般添加环境变量都添加在用户变量中,但只针对这一用户生效 为了使的所有用户都能正常使用软件,通常添加系统变量
- linux中安装mysq5.7
linux中安装mysq5.7 一. 安装mysql yum install mariadb-server mariadb 二. 开启mysql service mysqld start 四. 停止m ...
- Android Qcom USB Driver学习(十三)
DPM Device Policy Manager deals with the USB Power Delivery resources used by one or more ports on t ...
- python中模块的概念以及常用模块
模块的概念:为了减少常用代码重复输入,同时方便多人协作,python中定义了模块一词. 模块是一些函数的集合.在python中可以使用import导入某一模块的单个或者所有功能. python中的模块 ...
- rabbitmq 新下载链接🔗
Linux下安装RabbitMQ需要依赖socat和erlang插件环境 1 插件下载 1.1 RabbitMQ下载 下载地址一:https://www.rabbitmq.com/download. ...
- 让容器通信变得简单:深度解析 Containerd 中的 CNI 插件
作者:尹珉,KubeSphere Ambassador & contributor,KubeSphere 社区用户委员会杭州站站长. 引言 在上一篇文章中,我们详细讨论了 Kubernetes ...
- 使用 KubeKey v3.1.1 离线部署原生 Kubernetes v1.28.8 实战
今天,我将为大家实战演示,如何基于操作系统 openEuler 22.03 LTS SP3,利用 KubeKey 制作 Kubernetes 离线安装包,并实战离线部署 Kubernetes v1.2 ...