首页 > 解决方案 > 如何在 Jetpack compose 中使用 EditText 或 TextInput 小部件?

问题描述

我通过尝试一些像 Image 和 EditText 这样的小部件来探索 Jetpack compose。

对于文本输入,它具有EditableText. 我试过下面的代码,但它没有在 UI 中显示任何内容

class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            loadUi()
        }
    }

    @Composable
    fun loadUi() {
        CraneWrapper {
            MaterialTheme {
                val state = +state { EditorState("") }
                EditableText(
                    value = state.value,
                    onValueChange = { state.value = it },
                    editorStyle = EditorStyle(
                        textStyle = TextStyle(
                            fontSize = (50f)
                        )
                    )
                )
            }
        }
    }
}

我在这里想念什么?任何帮助,将不胜感激!

标签: androidandroidxandroid-jetpack-composeandroid-compose-textfield

解决方案


正如Gabriele Mariotti的回答所述,这是正确的做法:

var text by rememberSaveable { mutableStateOf("Text") }

TextField(
    value = text,
    onValueChange = {
        text = it
    },
    label = { Text("Label") }
)

但是,如果您遇到以下错误:

类型“TypeVariable(T)”没有方法“getValue(MainActivity, KProperty<*>)”,因此它不能用作委托

只需将这两个导入添加到您的文件中,您就可以了:

import androidx.compose.runtime.getValue
import androidx.compose.runtime.setValue

推荐阅读