如何将 ViewModel 与 Jetpack Compose 结合使用?

Arf*_*ain 16 android mvvm kotlin android-viewmodel android-jetpack-compose

我正在尝试通过进行数字增量来将ViewModel与 Jetpack Compose 结合使用。

它不起作用。也许我没有以正确的方式使用 ViewModel。

这是我的活动代码:

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() {
    AppTheme {
        Greeting()
    }
}
Run Code Online (Sandbox Code Playgroud)

这是我的视图模型代码:

class ViewModel: ViewModel() {
    var number : Int = 0
    fun addNumber(){
        number++
    }
}
Run Code Online (Sandbox Code Playgroud)

有什么想法我做错了吗?

Phi*_*hov 20

除非该值包含在State对象中,否则您的Composable将不会获取值的更改。您可以使用mutableStateOf()mutableIntStateOf()将值包装在可变State属性中,如下所示:ViewModel.number

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

    fun addNumber(){
        number++
    }
}
Run Code Online (Sandbox Code Playgroud)

或者,您可以将该属性声明为LiveDataFlow,然后使用LiveData.observeAsState()Flow.collectAsState扩展函数将该值引用为Composable中的State对象。

我建议您从State 和 Jetpack Compose文档以及Jetpack Compose:State YouTube 视频开始。这两个资源解释了基本原理。