Compose中的状态

大家好,今天我们来讲一下Compose中的状态。 我们之前说过,应用简单来说就是界面+数据。所以我们今天就一起来看一下Compose是怎么记录数据的。Compose中通过State可以来记录数据,记录和程序界面的交互。 我们一起来新建一个简单的计数器程序,工程命名为ComposeLesson2。 这个计数器程序如下图:

图中有一个文本用于显示计数的值,一个按钮用来实现加1功能。

我们来看一下下面不用State的代码:

kotlin 复制代码
@Composable
fun AddNumber() {
    var num = 0 //Don't do this
    Row {
        Text(
            num.toString(),
            modifier = Modifier.padding(10.dp)
        )

        ElevatedButton(
            onClick = {
                num += 1
            },
            modifier = Modifier.padding(start = 10.dp)
        ) {
            Text("+1")
        }
    }
}

这时候我们点击+1按钮是没有反应的。

上述的代码无法按预期发挥作用。为变量num设置不同的值不会使Compose检测到其状态更改,因此不会产生任何效果。

同时,上述函数中第一行将num设置为0. 可组合函数在界面中可以按照任意顺序频繁执行,每一次进入该函数都会使num变量被重新赋值为0.

如需向可组合函数中添加内部状态,可以使用mutableStateOf函数。该函数可以让Compose重组读取最新状态。

同时,为了使重组后能记住之前的状态,我们需要使用remember函数。

使用remember后的函数的程序如下:

scss 复制代码
@Composable
fun AddNumber() {
    var num by remember {
        mutableStateOf(0)
    }
    Row {
        Text(
            num.value.toString(),
            modifier = Modifier.padding(10.dp)
        )

        ElevatedButton(
            onClick = {
                num.value += 1
            },
            modifier = Modifier.padding(start = 10.dp)
        ) {
            Text("+1")
        }
    }
}

上述程序中,我们用到了remember和mutableStateOf,这时再取num的值时就需要用.value。

为了方便,我们可以使用by关键字来实现属性委托:

我们把=改成by,最终程序如下:

scss 复制代码
@Composable
fun AddNumber() {
    var num by remember {
        mutableStateOf(0)
    }
    Row {
        Text(
            num.toString(),
            modifier = Modifier.padding(10.dp)
        )

        ElevatedButton(
            onClick = {
                num += 1
            },
            modifier = Modifier.padding(start = 10.dp)
        ) {
            Text("+1")
        }
    }
}

运行后我们再来点击一下+1按钮,就可以看到实现了+1的效果。

本文的代码已提交到以下github地址:

github.com/gucheng3116...

相关推荐
lw向北.3 分钟前
Qt For Android之环境搭建(Qt 5.12.11 Qt下载SDK的处理方案)
android·开发语言·qt
不爱学习的啊Biao11 分钟前
【13】MySQL如何选择合适的索引?
android·数据库·mysql
Clockwiseee39 分钟前
PHP伪协议总结
android·开发语言·php
mmsx7 小时前
android sqlite 数据库简单封装示例(java)
android·java·数据库
众拾达人10 小时前
Android自动化测试实战 Java篇 主流工具 框架 脚本
android·java·开发语言
吃着火锅x唱着歌11 小时前
PHP7内核剖析 学习笔记 第四章 内存管理(1)
android·笔记·学习
_Shirley12 小时前
鸿蒙设置app更新跳转华为市场
android·华为·kotlin·harmonyos·鸿蒙
hedalei14 小时前
RK3576 Android14编译OTA包提示java.lang.UnsupportedClassVersionError问题
android·android14·rk3576
锋风Fengfeng14 小时前
安卓多渠道apk配置不同签名
android
枫_feng15 小时前
AOSP开发环境配置
android·安卓