我正在嘗試ViewModel與 Jetpack Compose一起使用,
通過做一個數字增量。
但它不起作用。也許我沒有以正確的方式使用視圖模型。
這是我的主要活動代碼
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。
我如何創建視圖模型的物件:
class ViewModel: ViewModel() {
var number : Int = 0
fun addNumber(){
number
}
}
uj5u.com熱心網友回復:
當一些具有可變狀態值的容器發生變化時,Compose 可以重構。您可以使用mutableStateOf()、 mutableStateListOf()等手動創建它,或者通過包裝Flow/來創建它LiveData。
class ViewModel: ViewModel() {
var number : Int by mutableStateOf(0)
fun addNumber(){
number
}
}
我建議您從撰寫檔案中的state 開始,包括解釋基本原理的這個 youtube 視頻。
轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/339710.html
