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协议越来越受欢迎和被采用,越来越多的系统会在应用程 ...
随机推荐
- SQL 高级语法 MERGE INTO
根据与源表相联接的结果,对目标表进行插入.更新.删除等操作. 例如,对目标表,如果源表存在的数据则更新,没有的则插入,就可以使用MEREG进行同步. 基本语法 MERGE INTO target_ta ...
- Fluent Builder 模式
前言 以前最讨厌设计复杂方法调用, 就是那种需要一堆有逻辑规则的 config 作为参数的方法. 这种 config 通常是一个大对象, 有许多 property, property 之间有存在一些逻 ...
- [34](CSP 集训)CSP-S 联训模拟 1
A 几何 重复若干次 -> 不能重叠,因此考虑直接暴力 DP 设 \(f_{i,j,k}\) 表示主串匹配到第 \(i\) 位(将前 \(i\) 位分别归为两类),其中 \(x\) 在重复了若干 ...
- Linux-USB驱动笔记-Gadget Function驱动
1.前言 在Linux-USB驱动笔记(四)–USB整体框架中有説到Gadget Function驱动,下面我们来具体看一下. Gadget Function就是指设备的功能,比如作为U盘,需要文件存 ...
- 忽略某个已经托管给git的文件,防止二次提交
# 执行命令将文件加入不提交队列 git update-index --assume-unchanged 你的文件路径 # 执行命令将文件取消加入不提交队列 git update-index --no ...
- 激活windows教程
新建bat文件 [批处理文件:后缀是 bat ] 输入代码: slmgr/skms kms.03k.org slmgr/ato 然后以管理员运行 :
- 王树森Attention与Self-Attention学习笔记
目录 Seq2Seq + Attention Attention的原理 方法一(Used in the original paper) 方法二(more popular,the same to Tra ...
- 云原生周刊 | 使用 kube-reqsizer 自动调整资源配额
开源项目推荐 kptop Kubernetes API 提供的监控指标非常有限,而 kubectl top 就是利用 Kubernetes API 来查看 Node 和 Pod 的实时资源使用情况.k ...
- Visual Studio NUGET 清理方法
NUGET全局包存储位置配置 NuGet缓存实在是太大了,把我唯一的120G固态硬盘(系统盘)基本占用完了--只能是清理一下了,同时修改缓存路径到其他盘以便一劳永逸. 1. 在C:\Program F ...
- CMDB实践指南:项目规划与实施策略解析
随着现代企业IT系统的日益复杂,如何有效管理这些庞大的IT资产和资源,成为每个企业必须面对的重要问题.CMDB应运而生,帮助企业集中管理IT资源,维护系统的稳定性,并支持故障排查与决策制定.本文将深入 ...