ViewModel

沒有ViewModel

以下的程式碼,會因為畫面旋轉,重繪畫面,導致資料變成0。

MainActivity08

1
2
3
4
5
6
7
8
9
10
11
12
13
class MainActivity08 : AppCompatActivity() {
  var number = 0
  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    val submit = findViewById<Button>(R.id.button)
    val textv = findViewById<TextView>(R.id.textView)
    submit.setOnClickListener {
      number++
      textv.text = number.toString()
    }
  }
}

xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/main"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".activity.MainActivity07">

    <TextView
        android:id="@+id/textView"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="0"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <Button
        android:id="@+id/button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Add"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/textView" />

</androidx.constraintlayout.widget.ConstraintLayout>

ViewModel

viewModel可以保存資料,不會因為畫面旋轉(重繪),而導致資料變成0。

NumberViewModel

1
2
3
4
5
6
7
8
import androidx.lifecycle.ViewModel

class NumberViewModel : ViewModel() {
  var number = 0
  fun increase() {
    number++
  }
}

MainActivity08

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class MainActivity08 : AppCompatActivity() {
  private val viewModel by viewModels<NumberViewModel>()
  var number = 0
  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    val submit = findViewById<Button>(R.id.button)
    val textv = findViewById<TextView>(R.id.textView)

    submit.setOnClickListener {
      viewModel.increase()
      textv.text = viewModel.number.toString()
    }
  }
}

results matching ""

    No results matching ""