Kotlin Jetpack組件ViewModel使用詳解
1.ViewModel的出現(xiàn)
ViewModel應(yīng)該是Jetpack中最重要的組件之一了。在以前,Activity要負(fù)責(zé)邏輯處理,又要控制UI展示,還要處理網(wǎng)絡(luò)回調(diào),導(dǎo)致大型項(xiàng)目難以維護(hù)。于是,ViewModel來幫助Activity分擔(dān)一部分工作,ViewModel就專門用于存放和界面相關(guān)的工作。
2.ViewModel的使用
基本步驟
在app/build.gradel文件添加依賴
dependencies{
...
implementation "androidx.lifecycle:lifecycle-extensions:2.2.0"
}
創(chuàng)建ViewModel的子類
class MainViewModel:ViewModel(){
var counter=0
}在MainActivity中創(chuàng)建ViewModel的實(shí)例
viewModel=ViewModelProvider(this).get(MainViewModel::class.java)
ViewModel的作用
手機(jī)發(fā)生橫縱屏旋轉(zhuǎn)的時(shí)候,存放在Activity的數(shù)據(jù)不會(huì)丟失。
由圖一可以看出ViewModel的生命周期比Activity的生命周期長,所以Activity旋轉(zhuǎn)的時(shí)候,ViewModel的數(shù)據(jù)任然存在。
圖一:

下面我們通過普通的計(jì)算器來實(shí)現(xiàn)這個(gè)功能
在界面上添加一個(gè)按鈕,每點(diǎn)擊一次按鈕就讓計(jì)算器加1,并且把最新的計(jì)數(shù)顯示在頁面上,運(yùn)行完成后,不管你怎樣翻轉(zhuǎn),頁面的數(shù)據(jù)不會(huì)丟失。
在布局文件中添加按鈕和TextView
<TextView
android:id="@+id/infoText"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:textSize="32sp" />
<Button
android:id="@+id/plusOneBtn"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:text="Plus One"/>創(chuàng)建ViewModel的子類
class MainViewModel: ViewModel() {
var counter=0
}在MainActivity中調(diào)用ViewModel的實(shí)例,每點(diǎn)擊一次按鈕就讓計(jì)算器加1。
class MainActivity : AppCompatActivity() {
lateinit var viewModel: MainViewModel
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
viewModel=ViewModelProvider(this).get(MainViewModel::class.java)
val plusOneBtn:Button=findViewById(R.id.plusOneBtn)
plusOneBtn.setOnClickListener {
viewModel.counter++
refreshCounter()
}
refreshCounter()
}
private fun refreshCounter() {
val infoText:TextView=findViewById(R.id.infoText)
infoText.text=viewModel.counter.toString()
}
}退出程序后再打開,頁面數(shù)據(jù)不會(huì)丟失。
實(shí)現(xiàn)這個(gè)功能,我們需要在退出程序的時(shí)候?qū)Ξ?dāng)前這個(gè)計(jì)數(shù)進(jìn)行保存,然后在重新打開這個(gè)程序的時(shí)候讀取之前保存的計(jì)數(shù),并將這個(gè)計(jì)數(shù)作為參數(shù)傳遞給MainViewModel。
創(chuàng)建ViewModel的子類,給MainViewModel的構(gòu)造函數(shù)添加參數(shù)
class MainViewModel(countReserved:Int): ViewModel() {
var counter=countReserved
}創(chuàng)建ViewModelProvider.Factory的子類,在這個(gè)類里面創(chuàng)建ViewModel的實(shí)例并且給ViewModel的構(gòu)造函數(shù)賦值。
class MainViewModelFactory(private val countReserved:Int): ViewModelProvider.Factory {
override fun <T : ViewModel?> create(modelClass: Class<T>): T {
return MainViewModel(countReserved) as T
//這個(gè)create方法的執(zhí)行事件和Activity的生命周期無關(guān),所以可以直接使用MainViewModel來創(chuàng)建實(shí)例
}
}退出程序的時(shí)候?qū)Ξ?dāng)前這個(gè)計(jì)數(shù)進(jìn)行保存,然后在重新打開這個(gè)程序的時(shí)候讀取之前保存的計(jì)數(shù),并將這個(gè)計(jì)數(shù)作為參數(shù)傳遞給MainViewModel,每點(diǎn)擊一次按鈕就讓計(jì)算器加1,并且把最新的計(jì)數(shù)顯示在頁面上。
class MainActivity : AppCompatActivity() {
lateinit var viewModel: MainViewModel
lateinit var sp:SharedPreferences
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val countReserved=sp.getInt("count_reserved",0)
viewModel=ViewModelProvider(this,MainViewModelFactory(countReserved)).get(MainViewModel::class.java)
sp=getSharedPreferences("data",Context.MODE_PRIVATE)
val plusOneBtn:Button=findViewById(R.id.plusOneBtn)
plusOneBtn.setOnClickListener {
viewModel.counter++
refreshCounter()
}
refreshCounter()
}
override fun onPause() {
super.onPause()
sp.edit().putInt("count_reserved",viewModel.counter)
}
private fun refreshCounter() {
val infoText:TextView=findViewById(R.id.infoText)
infoText.text=viewModel.counter.toString()
}
}到此這篇關(guān)于Kotlin Jetpack組件ViewModel使用詳解的文章就介紹到這了,更多相關(guān)Kotlin ViewModel內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android activity動(dòng)畫不生效原因及解決方案總結(jié)
android activity動(dòng)畫是一個(gè)比較簡單的功能。但是使用時(shí)總會(huì)由于各種小問題導(dǎo)致動(dòng)畫失效,筆者根據(jù)自己經(jīng)驗(yàn),整理了各種可能導(dǎo)致的原因,期望能對(duì)你有所幫助2021-11-11
Activit跳轉(zhuǎn)動(dòng)畫之界面上某個(gè)位置并裂開上下拉伸動(dòng)畫跳轉(zhuǎn)
這篇文章主要介紹了Activit跳轉(zhuǎn)動(dòng)畫之界面上某個(gè)位置并裂開上下拉伸動(dòng)畫跳轉(zhuǎn)的相關(guān)資料,需要的朋友可以參考下2016-07-07
Android中使用achartengine生成圖表的具體方法
這篇文章主要介紹了Android中使用achartengine生成圖表的具體方法,有需要的朋友可以參考一下2014-01-01
Android開發(fā)調(diào)用WebService的方法示例
這篇文章主要介紹了Android開發(fā)調(diào)用WebService的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android調(diào)用WebService的原理、實(shí)現(xiàn)方法與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2017-10-10
Android camera2 判斷相機(jī)功能是否可控的實(shí)例
下面小編就為大家?guī)硪黄狝ndroid camera2 判斷相機(jī)功能是否可控的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-03-03
Flutter利用Hero組件實(shí)現(xiàn)自定義路徑效果的動(dòng)畫
本篇介紹了如何利用Hero動(dòng)畫組件的createRectTween屬性實(shí)現(xiàn)自定義路徑效果的動(dòng)畫。文中的示例代碼講解詳細(xì),感興趣的可以了解一下2022-06-06
Android實(shí)現(xiàn)后臺(tái)服務(wù)拍照功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)后臺(tái)服務(wù)拍照功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
Android編程簡單設(shè)置ListView分割線的方法
這篇文章主要介紹了Android編程簡單設(shè)置ListView分割線的方法,涉及Android布局簡單操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02

