android - 如何在 Jetpack 组合中使用 Viewmodel

标签 android kotlin mvvm android-jetpack-compose android-viewmodel

我正在尝试使用 ViewModel使用 Jetpack Compose,
通过做一个数字增量。
但它不起作用。也许我没有以正确的方式使用 View 模型。
这是我的主要 Activity 代码

class MainActivity : ComponentActivity() {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContent {
            Greeting()
        }
    }
}

@Composable
fun Greeting(
    helloViewModel: ViewModel = viewModel()
) {
    Column(
        verticalArrangement = Arrangement.Center,
        horizontalAlignment = Alignment.CenterHorizontally,
        modifier = Modifier.fillMaxSize()
    ) {
        Text(
            text = helloViewModel.number.toString(),
            fontSize = 60.sp,
            fontWeight = FontWeight.Bold
        )
        Button(onClick = { helloViewModel.addNumber() }) {
            Text(text = "Increment Number ${helloViewModel.number}")
        }

    }
}

@Preview(showBackground = true)
@Composable
fun DefaultPreview() {
    JetpackcomposepracticeTheme {
        Greeting()
    }
}
这是我的 Viewmodel 类。
它适用于 xml。
我如何创建 View 模型的对象:
class ViewModel: ViewModel() {
    var number : Int = 0
    fun addNumber(){
        number++
    }
}

最佳答案

当一些具有可变状态值的容器发生变化时,Compose 可以重新组合。您可以使用 mutableStateOf() 手动创建它。 , mutableStateListOf()等,或通过包装 Flow/LiveData .

class ViewModel: ViewModel() {
    var number : Int by mutableStateOf(0)
        private set

    fun addNumber(){
        number++
    }
}
我建议你从 compose documentation 中的状态开始,包括 this youtube video它解释了基本原理。

关于android - 如何在 Jetpack 组合中使用 Viewmodel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69742278/

相关文章:

android - 如何在 Android 应用程序上使用 Google+ 帐户提供多用户访问权限

android - 如何以某个角度倾斜子布局

android - 为什么主要 Activity 在其调用的 Intent 完成后再次重启(Android 4.2.2)?

kotlin - 需要 <对象> 并找到 <对象>?

android - RoomProcessor 编译或循环依赖

silverlight - 在 Silverlight 3.0 中结合 .NET RIA 服务和 MVVM

android - 使用 JAVA 8 进行 android 开发是一个好习惯吗?

android - Unresolved reference : viewModelScope - Android KTX

c# - 多线程流文档

wpf - MVVM Light 中 View 模型之间的通信