Kotlin Jetpack組件ViewModel使用詳解
1.ViewModel的出現(xiàn)
ViewModel應(yīng)該是Jetpack中最重要的組件之一了。在以前,Activity要負(fù)責(zé)邏輯處理,又要控制UI展示,還要處理網(wǎng)絡(luò)回調(diào),導(dǎo)致大型項目難以維護(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的實例
viewModel=ViewModelProvider(this).get(MainViewModel::class.java)
ViewModel的作用
手機(jī)發(fā)生橫縱屏旋轉(zhuǎn)的時候,存放在Activity的數(shù)據(jù)不會丟失。
由圖一可以看出ViewModel的生命周期比Activity的生命周期長,所以Activity旋轉(zhuǎn)的時候,ViewModel的數(shù)據(jù)任然存在。
圖一:
下面我們通過普通的計算器來實現(xiàn)這個功能
在界面上添加一個按鈕,每點擊一次按鈕就讓計算器加1,并且把最新的計數(shù)顯示在頁面上,運(yùn)行完成后,不管你怎樣翻轉(zhuǎn),頁面的數(shù)據(jù)不會丟失。
在布局文件中添加按鈕和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的實例,每點擊一次按鈕就讓計算器加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ù)不會丟失。
實現(xiàn)這個功能,我們需要在退出程序的時候?qū)Ξ?dāng)前這個計數(shù)進(jìn)行保存,然后在重新打開這個程序的時候讀取之前保存的計數(shù),并將這個計數(shù)作為參數(shù)傳遞給MainViewModel。
創(chuàng)建ViewModel的子類,給MainViewModel的構(gòu)造函數(shù)添加參數(shù)
class MainViewModel(countReserved:Int): ViewModel() { var counter=countReserved }
創(chuàng)建ViewModelProvider.Factory的子類,在這個類里面創(chuàng)建ViewModel的實例并且給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 //這個create方法的執(zhí)行事件和Activity的生命周期無關(guān),所以可以直接使用MainViewModel來創(chuàng)建實例 } }
退出程序的時候?qū)Ξ?dāng)前這個計數(shù)進(jìn)行保存,然后在重新打開這個程序的時候讀取之前保存的計數(shù),并將這個計數(shù)作為參數(shù)傳遞給MainViewModel,每點擊一次按鈕就讓計算器加1,并且把最新的計數(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)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android懸浮窗按鈕實現(xiàn)點擊并顯示/隱藏多功能列表
這篇文章主要為大家詳細(xì)介紹了Android懸浮窗按鈕實現(xiàn)點擊并顯示/隱藏多功能列表,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07Android實戰(zhàn)RecyclerView頭部尾部添加方法示例
本篇文章主要介紹了Android實戰(zhàn)RecyclerView頭部尾部添加方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11Android中ViewPager組件的基本用法及實現(xiàn)圖片切換的示例
這篇文章主要介紹了Android中ViewPager組件的基本用法及實現(xiàn)圖片切換的示例,ViewPager主要被用來實現(xiàn)滑動切換效果,需要的朋友可以參考下2016-03-03使用DrawerLayout組件實現(xiàn)側(cè)滑抽屜的功能
DrawerLayout組件同樣是V4包中的組件,也是直接繼承于ViewGroup類,所以說是一個容器類,下面通過本文給大家介紹使用DrawerLayout組件實現(xiàn)側(cè)滑抽屜的功能,感興趣的朋友一起看下吧2016-08-08OpenGL Shader實現(xiàn)光照發(fā)光體特效
這篇文章主要介紹了如何通過OpenGL Shader實現(xiàn)光照發(fā)光體特效,不同于陰影遮蓋,它是利用圓形繪制向內(nèi)部。感興趣的小伙伴可以了解一下2022-02-02