Android开发(Kotlin) ViewModel基本用法

ViewModel基本用法

创建viewmodel

kotlin 复制代码
class MyViewModel: ViewModel() {
}

实现一个计数器

kotlin 复制代码
class MyViewModel : ViewModel() {


    var count = 0
}

在activity使用ViewModel,获取ViewModel的实例需要通过ViewModelProvider。点击按钮一次计数器加1

kotlin 复制代码
  override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        enableEdgeToEdge()
        binding = ActivityClickBinding.inflate(layoutInflater)
        setContentView(binding.root)

        viewModel = ViewModelProvider(this).get(MyViewModel::class.java)

        binding.clickButC.setOnClickListener {

            viewModel.count++
            refreshCount()

        }
        refreshCount()
    }

    private fun refreshCount() {

        binding.clickTvText.text = viewModel.count.toString()
    }

旋转屏幕后,计数器的数据仍然存在

向ViewModel传递参数

改进上面的例子,保证退出程序后,重新打开,数据任然存在。

修改viewmodel

kotlin 复制代码
class MyViewModel(counter: Int) : ViewModel() {


    var count = counter
}

counter记录之前保存的值

创建ViewModelProvider.Factory ,向MyViewModel的构造函数传递数据。添加构造函数,重写create方法,

kotlin 复制代码
class MyViewModelFactory(private val counter: Int) : ViewModelProvider.Factory {


    override fun <T : ViewModel> create(modelClass: Class<T>): T {
        return MyViewModel(counter) as T
    }

}

修改activity

kotlin 复制代码
class ClickActivity : ComponentActivity() {


    lateinit var viewModel: MyViewModel
    lateinit var binding:ActivityClickBinding
    lateinit var sp: SharedPreferences

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        enableEdgeToEdge()
        binding = ActivityClickBinding.inflate(layoutInflater)
        setContentView(binding.root)

        sp = getSharedPreferences("data",MODE_PRIVATE)
        val countSp = sp.getInt("count",0)

        viewModel = ViewModelProvider(this, MyViewModelFactory(countSp)).get(MyViewModel::class.java)
        binding.clickButC.setOnClickListener {

            viewModel.count++
            refreshCount()
        }
        refreshCount()
    }

    private fun refreshCount() {

        binding.clickTvText.text = viewModel.count.toString()
    }

    override fun onPause() {
        super.onPause()
        sp.edit{

            putInt("count",viewModel.count)
        }
    }

}
相关推荐
冷雨夜中漫步7 小时前
Python快速入门(6)——for/if/while语句
开发语言·经验分享·笔记·python
百锦再8 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
2501_916008899 小时前
全面介绍Fiddler、Wireshark、HttpWatch、SmartSniff和firebug抓包工具功能与使用
android·ios·小程序·https·uni-app·iphone·webview
m0_736919109 小时前
C++代码风格检查工具
开发语言·c++·算法
2501_9449347310 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
玉梅小洋10 小时前
Windows 10 Android 构建配置指南
android·windows
黎雁·泠崖10 小时前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2301_7634724611 小时前
C++20概念(Concepts)入门指南
开发语言·c++·算法
Libraeking11 小时前
视觉篇:Canvas 自定义绘图与高级动画的华丽圆舞曲
android·经验分享·android jetpack
TechWJ11 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto