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中,我们可以使用ColumnRow组件来构建布局。

示例代码二
@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:状态管理与事件处理的更多相关文章

  1. 查收新年礼物丨DevEco Studio 3.0 Beta2发布,20个新变化详解

    HUAWEI DevEco Studio是开发HarmonyOS应用和原子化服务的一站式集成开发环境(IDE),为开发者提供工程模板创建.开发.编译.调试.发布等功能. 2021年12月31日,新版本 ...

  2. ASP.NET状态管理详解,让你明明白白

    开发WinFrom的程序员可能不会在意维护应用程序的状态,因为WinFrom本身就在客户端运行,可以直接在内存中维护其应用程序状态.但ASP.NET应用程序在服务器端运行,客户端使用无状态的http协 ...

  3. vuex状态管理

    msvue组件间通信时,若需要改变多组件间共用状态的值.通过简单的组件间传值就会遇到问题.如:子组件只能接收但改变不了父组件的值.由此,vuex的出现就是用作各组件间的状态管理. 简单实例:vuex的 ...

  4. 大数据计算引擎之Flink Flink状态管理和容错

    这里将介绍Flink对有状态计算的支持,其中包括状态计算和无状态计算的区别,以及在Flink中支持的不同状态类型,分别有 Keyed State 和 Operator State .另外针对状态数据的 ...

  5. Redux状态管理方法与实例

    状态管理是目前构建单页应用中不可或缺的一环,也是值得花时间学习的知识点.React官方推荐我们使用Redux来管理我们的React应用,同时也提供了Redux的文档来供我们学习,中文版地址为http: ...

  6. 表格搞定 Asp.net Web 状态管理

    最近在网上搜罗了 ASP.NET WEB 状态管理方面的一些内容,终于把这些内容整合总结了一下. 1. 希望自己通过整理,能够掌握一些,为自己投资. 2. 以便自己忘记,又要浪费时间搜罗. 3. 希望 ...

  7. [译]面向初学者的Asp.Net状态管理技术

    介绍 本文主要讲解Asp.Net应用程序中的状态管理技术(Asp.Net中有多种状态管理技术),并批判性地分析所有状态管理技术的优缺点. 背景 HTTP是无状态的协议.客户端发起一个请求,服务器响应完 ...

  8. [Asp.Net]状态管理(Session、Application、Cache)

    上篇博文介绍了在客户端状态管理的两种方式:http://www.cnblogs.com/wolf-sun/p/3329773.html.除了在客户端上保存状态外,还可以在服务器上保存状态.使用客户端的 ...

  9. [Asp.Net]状态管理(ViewState、Cookie)

    简介 HTTP协议是无状态的.从客户端到服务器的连接可以在每个请求之后关闭.但是一般需要把一些客户端信息从一个页面传送给另一个页面. 无状态的根本原因是:浏览器和服务器使用Socket通信,服务器将请 ...

  10. HttpClient_HttpClient 4.3.6 HTTP状态管理

    HTTP状态管理 最初的HTTP被设计成以状态.请求/应答为导向的协议,它被制作成是没有特殊条款的,以便在状态会话中能交换逻辑关系请求/应答.HTTP协议越来越受欢迎和被采用,越来越多的系统会在应用程 ...

随机推荐

  1. Qt 中实现异步散列器

    [写在前面] 在很多工作中,我们需要计算数据或者文件的散列值,例如登录或下载文件. 而在 Qt 中,负责这项工作的类为 QCryptographicHash. 关于 QCryptographicHas ...

  2. 深度DFS 和 广度BFS搜索算法学习

    目录 广度优先的动态图 深度优先的动态图 广度和深度的具体步骤 深度和广度的应用场景 图的两种遍历方式: 深度优先遍历(DFS--Depth First Search) 广度优先遍历(BFS--Bre ...

  3. .NET 开源高性能 MQTT 类库

    前言 随着物联网(IoT)技术的迅猛发展,MQTT(消息队列遥测传输)协议凭借其轻量级和高效性,已成为众多物联网应用的首选通信标准. MQTTnet 作为一个高性能的 .NET 开源库,为 .NET ...

  4. Windows系统环境变量

    添加环境变量: 添加系统变量,机器要重新启动 添加用户变量,机器不用重启: 一般添加环境变量都添加在用户变量中,但只针对这一用户生效 为了使的所有用户都能正常使用软件,通常添加系统变量

  5. linux中安装mysq5.7

    linux中安装mysq5.7 一. 安装mysql yum install mariadb-server mariadb 二. 开启mysql service mysqld start 四. 停止m ...

  6. Android Qcom USB Driver学习(十三)

    DPM Device Policy Manager deals with the USB Power Delivery resources used by one or more ports on t ...

  7. python中模块的概念以及常用模块

    模块的概念:为了减少常用代码重复输入,同时方便多人协作,python中定义了模块一词. 模块是一些函数的集合.在python中可以使用import导入某一模块的单个或者所有功能. python中的模块 ...

  8. rabbitmq 新下载链接🔗

    Linux下安装RabbitMQ需要依赖socat和erlang插件环境 1 插件下载  1.1 RabbitMQ下载 下载地址一:https://www.rabbitmq.com/download. ...

  9. 让容器通信变得简单:深度解析 Containerd 中的 CNI 插件

    作者:尹珉,KubeSphere Ambassador & contributor,KubeSphere 社区用户委员会杭州站站长. 引言 在上一篇文章中,我们详细讨论了 Kubernetes ...

  10. 使用 KubeKey v3.1.1 离线部署原生 Kubernetes v1.28.8 实战

    今天,我将为大家实战演示,如何基于操作系统 openEuler 22.03 LTS SP3,利用 KubeKey 制作 Kubernetes 离线安装包,并实战离线部署 Kubernetes v1.2 ...