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)
        }
    }

}
相关推荐
小红的布丁几秒前
Reactor 模型详解:单 Reactor、主从 Reactor 与 Netty 思想
android·java·开发语言
cch89184 分钟前
Laravel与ThinkPHP5.x核心对比
android
被摘下的星星8 分钟前
Java的类加载
java·开发语言
skilllite作者12 分钟前
SkillLite 多入口架构实战:CLI / Python SDK / MCP / Desktop / Swarm 一页理清
开发语言·人工智能·python·安全·架构·rust·agentskills
秋月的私语17 分钟前
遥感影像拼接线优化工具:基于Qt+GDAL+OpenCV的从零到一实践
开发语言·qt·opencv
xwz小王子26 分钟前
智元发布 GO-2:动作空间推理 + 全生命周期闭环,让机器人稳定可靠落地
开发语言·golang·机器人
charlie11451419126 分钟前
通用GUI编程技术——图形渲染实战(二十八)——图像格式与编解码:PNG/JPEG全掌握
开发语言·c++·windows·学习·图形渲染·win32
ZC跨境爬虫29 分钟前
海南大学交友平台登录页开发实战day4(解决python传输并读取登录信息的问题)
开发语言·前端·python·flask·html
wjs202431 分钟前
SQL LEN() 函数详解
开发语言
酿情师35 分钟前
PHP 反序列化漏洞与 POP 链详解:网络安全小白从零入门
android·web安全·php